localizer
ljw 2025-09-13 16:57:53 +08:00
commit 77fcdad50f
10 changed files with 275 additions and 17 deletions

View File

@ -43,8 +43,8 @@ public class OSSController {
*
*/
@PostMapping("/upload")
public void uploadFile(@RequestPart MultipartFile file) {
ossService.uploadFile(file);
public R<?> uploadFile(@RequestPart MultipartFile file) {
return R.success(ossService.uploadFile(file));
}
/**

View File

@ -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;
}

View File

@ -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();
}
}

View File

@ -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

View File

@ -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;
}

View File

@ -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;
}

View File

@ -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;
}

View File

@ -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
}
}

View File

@ -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"