|
|
@@ -25,24 +25,32 @@ import io.swagger.annotations.ApiOperation;
|
|
|
import io.swagger.annotations.ApiParam;
|
|
|
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
|
|
|
import lombok.AllArgsConstructor;
|
|
|
+
|
|
|
+import javax.servlet.http.HttpServletResponse;
|
|
|
import javax.validation.Valid;
|
|
|
|
|
|
import org.springblade.client.entity.CorpsDesc;
|
|
|
import org.springblade.client.entity.StorageDesc;
|
|
|
import org.springblade.client.feign.ICorpsDescClient;
|
|
|
import org.springblade.client.feign.IStorageClient;
|
|
|
+import org.springblade.core.excel.util.ExcelUtil;
|
|
|
import org.springblade.core.mp.support.Condition;
|
|
|
import org.springblade.core.mp.support.Query;
|
|
|
import org.springblade.core.secure.utils.AuthUtil;
|
|
|
import org.springblade.core.secure.utils.SecureUtil;
|
|
|
import org.springblade.core.tool.api.R;
|
|
|
+import org.springblade.core.tool.utils.BeanUtil;
|
|
|
import org.springblade.core.tool.utils.Func;
|
|
|
import org.springblade.deliver.goods.entity.DeliveryItems;
|
|
|
import org.springblade.deliver.goods.enums.DeliveryEnum;
|
|
|
import org.springblade.deliver.goods.enums.DeliveryStatusEnum;
|
|
|
+import org.springblade.deliver.goods.excel.SaleDeliveryExcel;
|
|
|
import org.springblade.deliver.goods.service.IDeliveryFeesService;
|
|
|
import org.springblade.deliver.goods.service.IDeliveryFilesService;
|
|
|
import org.springblade.deliver.goods.service.IDeliveryItemsService;
|
|
|
+import org.springblade.purchase.sales.excel.SaleOrderExcel;
|
|
|
+import org.springblade.purchase.sales.vo.OrderVO;
|
|
|
+import org.springblade.purchase.sales.vo.SalesDetailsVo;
|
|
|
import org.springblade.system.user.entity.User;
|
|
|
import org.springblade.system.user.feign.IUserClient;
|
|
|
import org.springframework.web.bind.annotation.*;
|
|
|
@@ -113,6 +121,8 @@ public class DeliveryController extends BladeController {
|
|
|
lambdaQueryWrapper.eq(Func.isNotEmpty(delivery.getCreateUser()),Delivery::getCreateUser,delivery.getCreateUser());//制单人
|
|
|
lambdaQueryWrapper.eq(Func.isNotEmpty(delivery.getStorageId()),Delivery::getStorageId,delivery.getStorageId());//仓库
|
|
|
lambdaQueryWrapper.eq(Func.isNotEmpty(delivery.getDeliveryStatus()),Delivery::getDeliveryStatus,delivery.getDeliveryStatus());//状态
|
|
|
+ lambdaQueryWrapper.ge(Func.isNotEmpty(delivery.getArrivalStartTime()),Delivery::getArrivalTime,delivery.getArrivalStartTime());//确认到货日期开始
|
|
|
+ lambdaQueryWrapper.le(Func.isNotEmpty(delivery.getArrivalEndTime()),Delivery::getArrivalTime,delivery.getArrivalEndTime());//确认到货日期结束
|
|
|
lambdaQueryWrapper.orderByDesc(Delivery::getId);
|
|
|
IPage<Delivery> pages = deliveryService.page(Condition.getPage(query), lambdaQueryWrapper);
|
|
|
if (CollectionUtils.isNotEmpty(pages.getRecords())){
|
|
|
@@ -136,7 +146,7 @@ public class DeliveryController extends BladeController {
|
|
|
|
|
|
R<User> user1 = iUserClient.userInfoById(item.getUpdateUser());
|
|
|
if (user1.isSuccess() && user1.getData() != null){
|
|
|
- item.setCreateUserName(user1.getData().getName());
|
|
|
+ item.setUpdateUserName(user1.getData().getName());
|
|
|
}
|
|
|
//仓库信息
|
|
|
StorageDesc storageDesc = iStorageClient.findById(item.getStorageId());
|
|
|
@@ -149,6 +159,75 @@ public class DeliveryController extends BladeController {
|
|
|
}
|
|
|
return R.data(pages);
|
|
|
}
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 客户收货导出
|
|
|
+ */
|
|
|
+ @GetMapping("/saleDeliveryExport")
|
|
|
+ @ApiOperation(value = "客户收货导出", notes = "传入delivery")
|
|
|
+ public void saleOrderExport(Delivery delivery, HttpServletResponse response){
|
|
|
+ LambdaQueryWrapper<Delivery> lambdaQueryWrapper = new LambdaQueryWrapper();
|
|
|
+ lambdaQueryWrapper.eq(Delivery::getIsDeleted,0);
|
|
|
+ lambdaQueryWrapper.eq(Delivery::getTenantId,SecureUtil.getTenantId());
|
|
|
+ lambdaQueryWrapper.eq(Delivery::getBillType,OrderTypeEnum.SHIP.getType());
|
|
|
+ lambdaQueryWrapper.eq(Delivery::getTradeType,OrderTypeEnum.DOMESTIC.getType());
|
|
|
+ lambdaQueryWrapper.eq(delivery.getSalesCompany()!=null,Delivery::getSalesCompany,delivery.getSalesCompany());
|
|
|
+ lambdaQueryWrapper.like(StringUtils.isNotBlank(delivery.getPurchaseMode()),Delivery::getPurchaseMode,delivery.getPurchaseMode());
|
|
|
+ lambdaQueryWrapper.ge(Func.isNotEmpty(delivery.getCreateStartTime()),Delivery::getCreateTime,delivery.getCreateStartTime());//制单日期开始
|
|
|
+ lambdaQueryWrapper.le(Func.isNotEmpty(delivery.getCreateEndTime()),Delivery::getCreateTime,delivery.getCreateEndTime());//制单日期结束
|
|
|
+ lambdaQueryWrapper.ge(Func.isNotEmpty(delivery.getBusinessStartDate()),Delivery::getBusinessDate,delivery.getBusinessStartDate());//发货日期开始
|
|
|
+ lambdaQueryWrapper.le(Func.isNotEmpty(delivery.getBusinessEndDate()),Delivery::getBusinessDate,delivery.getBusinessEndDate());//发货日期结束
|
|
|
+ lambdaQueryWrapper.like(Func.isNotEmpty(delivery.getOrgOrderNo()),Delivery::getOrgOrderNo,delivery.getOrgOrderNo());//销售订单号
|
|
|
+ lambdaQueryWrapper.eq(Func.isNotEmpty(delivery.getCorpId()),Delivery::getCorpId,delivery.getCorpId());//客户
|
|
|
+ lambdaQueryWrapper.eq(Func.isNotEmpty(delivery.getSalesCompany()),Delivery::getSalesCompany,delivery.getSalesCompany());//所属公司
|
|
|
+ lambdaQueryWrapper.like(Func.isNotEmpty(delivery.getArrivalAddress()),Delivery::getArrivalAddress,delivery.getArrivalAddress());//收货地址
|
|
|
+ lambdaQueryWrapper.like(Func.isNotEmpty(delivery.getArrivalContact()),Delivery::getArrivalContact,delivery.getArrivalContact());//收货人
|
|
|
+ lambdaQueryWrapper.like(Func.isNotEmpty(delivery.getArrivalTel()),Delivery::getArrivalTel,delivery.getArrivalTel());//收货电话
|
|
|
+ lambdaQueryWrapper.like(Func.isNotEmpty(delivery.getDeliveryRemarks()),Delivery::getDeliveryRemarks,delivery.getDeliveryRemarks());//备注
|
|
|
+ lambdaQueryWrapper.eq(Func.isNotEmpty(delivery.getCreateUser()),Delivery::getCreateUser,delivery.getCreateUser());//制单人
|
|
|
+ lambdaQueryWrapper.eq(Func.isNotEmpty(delivery.getStorageId()),Delivery::getStorageId,delivery.getStorageId());//仓库
|
|
|
+ lambdaQueryWrapper.eq(Func.isNotEmpty(delivery.getDeliveryStatus()),Delivery::getDeliveryStatus,delivery.getDeliveryStatus());//状态
|
|
|
+ lambdaQueryWrapper.ge(Func.isNotEmpty(delivery.getArrivalStartTime()),Delivery::getArrivalTime,delivery.getArrivalStartTime());//确认到货日期开始
|
|
|
+ lambdaQueryWrapper.le(Func.isNotEmpty(delivery.getArrivalEndTime()),Delivery::getArrivalTime,delivery.getArrivalEndTime());//确认到货日期结束
|
|
|
+ lambdaQueryWrapper.orderByDesc(Delivery::getId);
|
|
|
+ List<Delivery> list = deliveryService.list(lambdaQueryWrapper);
|
|
|
+ if (CollectionUtils.isNotEmpty(list)){
|
|
|
+ list.forEach(item ->{
|
|
|
+ if (item.getCorpId() != null){
|
|
|
+ R<CorpsDesc> corpMessage = corpsDescClient.getCorpMessage(item.getCorpId());
|
|
|
+ if (corpMessage.isSuccess() && corpMessage.getData() != null){
|
|
|
+ item.setCorpsName(corpMessage.getData().getCname());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (item.getSalesCompany() != null){
|
|
|
+ R<CorpsDesc> corpMessage = corpsDescClient.getCorpMessage(item.getSalesCompany());
|
|
|
+ if (corpMessage.isSuccess() && corpMessage.getData() != null){
|
|
|
+ item.setSalesCompanyName(corpMessage.getData().getCname());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ R<User> user = iUserClient.userInfoById(item.getCreateUser());
|
|
|
+ if (user.isSuccess() && user.getData() != null){
|
|
|
+ item.setCreateUserName(user.getData().getName());
|
|
|
+ }
|
|
|
+
|
|
|
+ R<User> user1 = iUserClient.userInfoById(item.getUpdateUser());
|
|
|
+ if (user1.isSuccess() && user1.getData() != null){
|
|
|
+ item.setUpdateUserName(user1.getData().getName());
|
|
|
+ }
|
|
|
+ //仓库信息
|
|
|
+ StorageDesc storageDesc = iStorageClient.findById(item.getStorageId());
|
|
|
+ if(storageDesc!=null)
|
|
|
+ {
|
|
|
+ item.setStorageName(storageDesc.getCname());
|
|
|
+ }
|
|
|
+
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ List<SaleDeliveryExcel> excelList = BeanUtil.copy(list, SaleDeliveryExcel.class);
|
|
|
+ ExcelUtil.export(response, "客户收货", "客户收货", excelList, SaleDeliveryExcel.class);
|
|
|
+
|
|
|
+ }
|
|
|
/**
|
|
|
* 自定义分页 国内发货通知单
|
|
|
*/
|
|
|
@@ -165,7 +244,7 @@ public class DeliveryController extends BladeController {
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
- * 确认发货通知单
|
|
|
+ * 确认收货
|
|
|
*/
|
|
|
@PostMapping("/save")
|
|
|
@ApiOperationSupport(order = 4)
|
|
|
@@ -191,7 +270,7 @@ public class DeliveryController extends BladeController {
|
|
|
return deliveryService.submit(delivery);
|
|
|
}
|
|
|
/**
|
|
|
- * 国内贸易发货单确认收货
|
|
|
+ * 国内贸易客户收货-确认到货
|
|
|
*/
|
|
|
@PostMapping("/takeDelivery")
|
|
|
@ApiOperationSupport(order = 4)
|
|
|
@@ -204,11 +283,11 @@ public class DeliveryController extends BladeController {
|
|
|
return deliveryService.revocation(delivery);
|
|
|
}
|
|
|
/**
|
|
|
- * 国内贸易发货单撤销确认收货
|
|
|
+ * 国内贸易发货单撤销确认到货
|
|
|
*/
|
|
|
@PostMapping("/revocation")
|
|
|
@ApiOperationSupport(order = 4)
|
|
|
- @ApiOperation(value = "国内贸易发货单撤销确认收货,确认收货才能点", notes = "传入delivery")
|
|
|
+ @ApiOperation(value = "国内贸易发货单撤销确认到货,确认收货才能点", notes = "传入delivery")
|
|
|
public R revocation(@Valid @RequestBody Delivery delivery) {
|
|
|
delivery.setBillType(OrderTypeEnum.SHIP.getType());
|
|
|
delivery.setTradeType(OrderTypeEnum.DOMESTIC.getType());
|