看料、指派清运公司/司机、司机确认接单、司机确认接单、取消订单
parent
eccd9bb275
commit
e672c238dd
|
|
@ -0,0 +1,20 @@
|
|||
package com.njzscloud.supervisory.order.contant;
|
||||
|
||||
import com.njzscloud.common.core.ienum.DictStr;
|
||||
import lombok.Getter;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
|
||||
/**
|
||||
* 字典代码:check_status
|
||||
* 字典名称:看料状态
|
||||
*/
|
||||
@Getter
|
||||
@RequiredArgsConstructor
|
||||
public enum CheckStatus implements DictStr {
|
||||
Wu("Wu", "无"),
|
||||
YiKanLiao("YiKanLiao", "已看料"),
|
||||
WeiKanLiao("WeiKanLiao", "未看料"),
|
||||
;
|
||||
private final String val;
|
||||
private final String txt;
|
||||
}
|
||||
|
|
@ -6,8 +6,7 @@ import com.njzscloud.common.mp.support.PageResult;
|
|||
import com.njzscloud.common.security.support.UserDetail;
|
||||
import com.njzscloud.common.security.util.SecurityUtil;
|
||||
import com.njzscloud.supervisory.order.pojo.entity.OrderInfoEntity;
|
||||
import com.njzscloud.supervisory.order.pojo.param.AuditOrderParam;
|
||||
import com.njzscloud.supervisory.order.pojo.param.OrderPagingSearchParam;
|
||||
import com.njzscloud.supervisory.order.pojo.param.*;
|
||||
import com.njzscloud.supervisory.order.pojo.result.OrderPagingResult;
|
||||
import com.njzscloud.supervisory.order.service.OrderInfoService;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
|
|
@ -90,4 +89,53 @@ public class OrderInfoController {
|
|||
return R.success();
|
||||
}
|
||||
|
||||
/**
|
||||
* 看料
|
||||
*/
|
||||
@GetMapping("/check")
|
||||
public R<?> check(CheckGoodsParam checkGoodsParam) {
|
||||
orderInfoService.check(checkGoodsParam);
|
||||
return R.success();
|
||||
}
|
||||
|
||||
/**
|
||||
* 指派清运公司/司机
|
||||
*/
|
||||
@GetMapping("/assignment")
|
||||
public R<?> assignment(AssignmentOrderParam assignmentOrderParam) {
|
||||
orderInfoService.assignment(assignmentOrderParam);
|
||||
return R.success();
|
||||
}
|
||||
|
||||
/**
|
||||
* 司机确认接单
|
||||
*
|
||||
* @param orderId 订单Id
|
||||
*/
|
||||
@GetMapping("/confirm")
|
||||
public R<?> confirm(@RequestParam("orderId") Long orderId) {
|
||||
orderInfoService.confirm(orderId);
|
||||
return R.success();
|
||||
}
|
||||
|
||||
/**
|
||||
* 司机确认接单
|
||||
*/
|
||||
@GetMapping("/start_trans")
|
||||
public R<?> startTrans(StartTransportOrderParam startTransportOrderParam) {
|
||||
orderInfoService.startTrans(startTransportOrderParam);
|
||||
return R.success();
|
||||
}
|
||||
|
||||
/**
|
||||
* 取消订单
|
||||
*
|
||||
* @param orderId 订单Id
|
||||
*/
|
||||
@GetMapping("/cancel")
|
||||
public R<?> cancel(@RequestParam("orderId") Long orderId) {
|
||||
orderInfoService.cancel(orderId);
|
||||
return R.success();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,11 +1,9 @@
|
|||
package com.njzscloud.supervisory.order.pojo.entity;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import com.njzscloud.common.mp.support.handler.j.JsonTypeHandler;
|
||||
import com.njzscloud.supervisory.biz.contant.AuditStatus;
|
||||
import com.njzscloud.supervisory.order.contant.OrderCategory;
|
||||
import com.njzscloud.supervisory.order.contant.OrderStatus;
|
||||
import com.njzscloud.supervisory.order.contant.PayerCategory;
|
||||
import com.njzscloud.supervisory.order.contant.PaymentStatus;
|
||||
import com.njzscloud.supervisory.order.contant.*;
|
||||
import lombok.Getter;
|
||||
import lombok.Setter;
|
||||
import lombok.ToString;
|
||||
|
|
@ -13,6 +11,7 @@ import lombok.experimental.Accessors;
|
|||
|
||||
import java.math.BigDecimal;
|
||||
import java.time.LocalDateTime;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 订单信息
|
||||
|
|
@ -21,7 +20,7 @@ import java.time.LocalDateTime;
|
|||
@Setter
|
||||
@ToString
|
||||
@Accessors(chain = true)
|
||||
@TableName("order_info")
|
||||
@TableName(value = "order_info", autoResultMap = true)
|
||||
public class OrderInfoEntity {
|
||||
|
||||
/**
|
||||
|
|
@ -40,6 +39,15 @@ public class OrderInfoEntity {
|
|||
*/
|
||||
private Long cargoPlaceId;
|
||||
|
||||
/**
|
||||
* 清运公司 Id
|
||||
*/
|
||||
private Long transCompanyId;
|
||||
|
||||
/**
|
||||
* 开始清运时间
|
||||
*/
|
||||
private LocalDateTime transTime;
|
||||
/**
|
||||
* 站点 Id
|
||||
*/
|
||||
|
|
@ -83,7 +91,7 @@ public class OrderInfoEntity {
|
|||
/**
|
||||
* 看料状态; 字典代码:check_status
|
||||
*/
|
||||
private String checkStatus;
|
||||
private CheckStatus checkStatus;
|
||||
|
||||
/**
|
||||
* 车辆 Id
|
||||
|
|
@ -148,12 +156,14 @@ public class OrderInfoEntity {
|
|||
/**
|
||||
* 装车照片
|
||||
*/
|
||||
private String cargoPhoto;
|
||||
@TableField(typeHandler = JsonTypeHandler.class)
|
||||
private List<String> cargoPhoto;
|
||||
|
||||
/**
|
||||
* 看料照片
|
||||
*/
|
||||
private String checkPhoto;
|
||||
@TableField(typeHandler = JsonTypeHandler.class)
|
||||
private List<String> checkPhoto;
|
||||
|
||||
/**
|
||||
* 创建人 Id; sys_user.id
|
||||
|
|
|
|||
|
|
@ -0,0 +1,25 @@
|
|||
package com.njzscloud.supervisory.order.pojo.param;
|
||||
|
||||
import lombok.Getter;
|
||||
import lombok.Setter;
|
||||
import lombok.ToString;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
@Getter
|
||||
@Setter
|
||||
@ToString
|
||||
@Accessors(chain = true)
|
||||
public class AssignmentOrderParam {
|
||||
/**
|
||||
* 订单Id
|
||||
*/
|
||||
private Long orderId;
|
||||
/**
|
||||
* 清运公司Id
|
||||
*/
|
||||
private Long transCompanyId;
|
||||
/**
|
||||
* 司机Id
|
||||
*/
|
||||
private Long driverId;
|
||||
}
|
||||
|
|
@ -0,0 +1,23 @@
|
|||
package com.njzscloud.supervisory.order.pojo.param;
|
||||
|
||||
import lombok.Getter;
|
||||
import lombok.Setter;
|
||||
import lombok.ToString;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Getter
|
||||
@Setter
|
||||
@ToString
|
||||
@Accessors(chain = true)
|
||||
public class CheckGoodsParam {
|
||||
/**
|
||||
* 订单Id
|
||||
*/
|
||||
private Long orderId;
|
||||
/**
|
||||
* 看料照片
|
||||
*/
|
||||
private List<String> checkPhoto;
|
||||
}
|
||||
|
|
@ -0,0 +1,24 @@
|
|||
package com.njzscloud.supervisory.order.pojo.param;
|
||||
|
||||
import lombok.Getter;
|
||||
import lombok.Setter;
|
||||
import lombok.ToString;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Getter
|
||||
@Setter
|
||||
@ToString
|
||||
@Accessors(chain = true)
|
||||
public class StartTransportOrderParam {
|
||||
/**
|
||||
* 订单Id
|
||||
*/
|
||||
private Long orderId;
|
||||
/**
|
||||
* 装车照片
|
||||
*/
|
||||
private List<String> cargoPhoto;
|
||||
|
||||
}
|
||||
|
|
@ -13,10 +13,11 @@ import com.njzscloud.common.security.util.SecurityUtil;
|
|||
import com.njzscloud.supervisory.biz.contant.AuditStatus;
|
||||
import com.njzscloud.supervisory.biz.pojo.entity.BizAuditConfigEntity;
|
||||
import com.njzscloud.supervisory.biz.service.BizAuditConfigService;
|
||||
import com.njzscloud.supervisory.order.contant.CheckStatus;
|
||||
import com.njzscloud.supervisory.order.contant.OrderStatus;
|
||||
import com.njzscloud.supervisory.order.mapper.OrderInfoMapper;
|
||||
import com.njzscloud.supervisory.order.pojo.entity.OrderInfoEntity;
|
||||
import com.njzscloud.supervisory.order.pojo.param.AuditOrderParam;
|
||||
import com.njzscloud.supervisory.order.pojo.param.OrderPagingSearchParam;
|
||||
import com.njzscloud.supervisory.order.pojo.param.*;
|
||||
import com.njzscloud.supervisory.order.pojo.result.OrderPagingResult;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
|
|
@ -148,4 +149,94 @@ public class OrderInfoService extends ServiceImpl<OrderInfoMapper, OrderInfoEnti
|
|||
.setAuditMemo(auditOrderParam.getAuditMemo())
|
||||
);
|
||||
}
|
||||
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public void check(CheckGoodsParam checkGoodsParam) {
|
||||
OrderInfoEntity oldOrder = this.getById(checkGoodsParam.getOrderId());
|
||||
Assert.notNull(oldOrder, () -> Exceptions.clierr("订单不存在"));
|
||||
CheckStatus checkStatus = oldOrder.getCheckStatus();
|
||||
Assert.isFalse(checkStatus == null, () -> Exceptions.clierr("当前订单无需看料"));
|
||||
Assert.isFalse(CheckStatus.YiKanLiao == checkStatus, () -> Exceptions.clierr("当前订单已看料"));
|
||||
|
||||
this.updateById(new OrderInfoEntity()
|
||||
.setCheckPhoto(checkGoodsParam.getCheckPhoto())
|
||||
.setCheckStatus(CheckStatus.YiKanLiao)
|
||||
.setCheckerId(SecurityUtil.currentUserId())
|
||||
);
|
||||
}
|
||||
|
||||
public void assignment(AssignmentOrderParam assignmentOrderParam) {
|
||||
OrderInfoEntity oldOrder = this.getById(assignmentOrderParam.getOrderId());
|
||||
Assert.notNull(oldOrder, () -> Exceptions.clierr("订单不存在"));
|
||||
boolean assignmented = assignmentTrafficCompany(assignmentOrderParam, oldOrder);
|
||||
if (assignmented) {
|
||||
oldOrder.setOrderStatus(OrderStatus.DaiPaiDan);
|
||||
}
|
||||
assignmentDriver(assignmentOrderParam, oldOrder);
|
||||
}
|
||||
|
||||
private void assignmentDriver(AssignmentOrderParam assignmentOrderParam, OrderInfoEntity orderInfo) {
|
||||
Long driverId = assignmentOrderParam.getDriverId();
|
||||
if (driverId == null) return;
|
||||
Assert.isNull(orderInfo.getDriverId(), () -> Exceptions.clierr("当前订单已分配司机,无需重复分配"));
|
||||
Assert.isTrue(orderInfo.getOrderStatus() == OrderStatus.DaiPaiDan, () -> Exceptions.clierr("当前订单状态,无法分配司机"));
|
||||
|
||||
this.updateById(new OrderInfoEntity()
|
||||
.setId(orderInfo.getId())
|
||||
.setDriverId(driverId)
|
||||
.setOrderStatus(OrderStatus.DaiJieDan)
|
||||
);
|
||||
}
|
||||
|
||||
private boolean assignmentTrafficCompany(AssignmentOrderParam assignmentOrderParam, OrderInfoEntity orderInfo) {
|
||||
Long transCompanyId = assignmentOrderParam.getTransCompanyId();
|
||||
if (transCompanyId == null) return false;
|
||||
Assert.isNull(orderInfo.getTransCompanyId(), () -> Exceptions.clierr("当前订单已分配清运公司,无需重复分配"));
|
||||
Assert.isTrue(orderInfo.getOrderStatus() == OrderStatus.YiYuYue, () -> Exceptions.clierr("当前订单状态,无法分配清运公司"));
|
||||
|
||||
this.updateById(new OrderInfoEntity()
|
||||
.setId(orderInfo.getId())
|
||||
.setTransCompanyId(transCompanyId)
|
||||
.setOrderStatus(OrderStatus.DaiPaiDan)
|
||||
);
|
||||
return true;
|
||||
}
|
||||
|
||||
public void confirm(Long orderId) {
|
||||
OrderInfoEntity orderInfo = this.getById(orderId);
|
||||
Assert.notNull(orderInfo, () -> Exceptions.clierr("订单不存在"));
|
||||
Assert.isTrue(orderInfo.getOrderStatus() == OrderStatus.DaiJieDan, () -> Exceptions.clierr("当前订单状态,无法确认接单"));
|
||||
this.updateById(new OrderInfoEntity()
|
||||
.setId(orderInfo.getId())
|
||||
.setOrderStatus(OrderStatus.YiJieDan)
|
||||
);
|
||||
}
|
||||
|
||||
public void startTrans(StartTransportOrderParam startTransportOrderParam) {
|
||||
OrderInfoEntity orderInfo = this.getById(startTransportOrderParam.getOrderId());
|
||||
Assert.notNull(orderInfo, () -> Exceptions.clierr("订单不存在"));
|
||||
Assert.isTrue(orderInfo.getOrderStatus() == OrderStatus.YiJieDan, () -> Exceptions.clierr("当前订单状态,无法开始运输"));
|
||||
this.updateById(new OrderInfoEntity()
|
||||
.setId(orderInfo.getId())
|
||||
.setCargoPhoto(startTransportOrderParam.getCargoPhoto())
|
||||
.setOrderStatus(OrderStatus.QingYunZhong)
|
||||
.setTransTime(LocalDateTime.now())
|
||||
);
|
||||
// TODO 获取 GPS
|
||||
}
|
||||
|
||||
public void cancel(Long orderId) {
|
||||
OrderInfoEntity orderInfo = this.getById(orderId);
|
||||
Assert.notNull(orderInfo, () -> Exceptions.clierr("订单不存在"));
|
||||
OrderStatus orderStatus = orderInfo.getOrderStatus();
|
||||
Assert.isTrue(orderStatus == OrderStatus.YiYuYue
|
||||
|| orderStatus == OrderStatus.DaiPaiDan
|
||||
|| orderStatus == OrderStatus.DaiJieDan
|
||||
, () -> Exceptions.clierr("当前订单状态,无法取消"));
|
||||
this.updateById(new OrderInfoEntity()
|
||||
.setId(orderInfo.getId())
|
||||
.setOrderStatus(OrderStatus.YiQuXiao)
|
||||
);
|
||||
// TODO 关闭 GPS
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@
|
|||
"avatar": "",
|
||||
"version": "4.9.4",
|
||||
"createdTime": "2023-4-13 11:53:52",
|
||||
"updatedTime": "2025-9-12 16:38:16",
|
||||
"updatedTime": "2025-9-12 22:42:33",
|
||||
"dbConns": [],
|
||||
"profile": {
|
||||
"default": {
|
||||
|
|
@ -10060,7 +10060,7 @@
|
|||
"id": "5C0F4129-75F7-4EF4-BEFE-AEF7F2853800"
|
||||
},
|
||||
{
|
||||
"defKey": "traffic_company_id",
|
||||
"defKey": "trans_company_id",
|
||||
"defName": "清运公司 Id",
|
||||
"comment": "",
|
||||
"type": "BIGINT",
|
||||
|
|
@ -10076,6 +10076,23 @@
|
|||
"extProps": {},
|
||||
"id": "0DE621DB-FDD5-4BF8-ACB4-6BAF52742049"
|
||||
},
|
||||
{
|
||||
"defKey": "trans_time",
|
||||
"defName": "开始清运时间",
|
||||
"comment": "",
|
||||
"type": "DATETIME",
|
||||
"len": "",
|
||||
"scale": "",
|
||||
"primaryKey": false,
|
||||
"notNull": false,
|
||||
"autoIncrement": false,
|
||||
"defaultValue": "",
|
||||
"hideInGraph": false,
|
||||
"refDict": "",
|
||||
"baseType": "A098BA98-4957-43EE-9F06-1CDC26D370E0",
|
||||
"extProps": {},
|
||||
"id": "9DDBBD73-62BE-4F01-8DB6-408ED8B8451E"
|
||||
},
|
||||
{
|
||||
"defKey": "user_id",
|
||||
"defName": "下单人 Id",
|
||||
|
|
@ -10190,7 +10207,7 @@
|
|||
"autoIncrement": false,
|
||||
"defaultValue": "",
|
||||
"hideInGraph": false,
|
||||
"refDict": "",
|
||||
"refDict": "F96FCFCB-659A-4038-A681-5F03ACC5F40C",
|
||||
"baseType": "AA07828C-4FCB-4EDA-9B51-53A3F264F231",
|
||||
"extProps": {},
|
||||
"id": "1C1F7749-1FD1-4529-BBAF-B9CC8BBF7E2A"
|
||||
|
|
|
|||
Loading…
Reference in New Issue