Browse Source

Merge remote-tracking branch 'origin/dev' into dev

fix-sign
zhenghaoyu 4 months ago
parent
commit
7deb0410a3
  1. 10
      blade-biz-common/src/main/java/org/springblade/common/constant/broadcast/FanoutConstants.java
  2. 8
      blade-biz-common/src/main/java/org/springblade/common/model/DistributionSignforVO.java
  3. 11
      blade-biz-common/src/main/java/org/springblade/common/model/PackageData.java
  4. 23
      blade-biz-common/src/main/java/org/springblade/common/model/workNode/PickUpByScanVO.java
  5. 3
      blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/feign/IBasicdataWarehouseClient.java
  6. 6
      blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/feign/IBasicdataWarehouseClientFallback.java
  7. 16
      blade-service-api/logpm-distribution-api/src/main/java/com/logpm/distribution/entity/QualityDeliverEntity.java
  8. 7
      blade-service-api/logpm-distribution-api/src/main/java/com/logpm/distribution/feign/IQualityDeliverClient.java
  9. 7
      blade-service-api/logpm-statisticsdata-api/pom.xml
  10. 4
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/dto/ExpenseWarehouseOrderDTO.java
  11. 5
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/dto/MerchantStatisticsDTO.java
  12. 103
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseOrderWarehouseTotalEntity.java
  13. 148
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseWarehouseDayEntity.java
  14. 117
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseWarehouseMonthEntity.java
  15. 89
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseWarehouseOrderEntity.java
  16. 121
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseWarehousePackageDayEntity.java
  17. 80
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseWarehouseTransitMonthEntity.java
  18. 30
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/StatisticsDistributionPackageEntity.java
  19. 9
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/StatisticsOrderInfoEntity.java
  20. 79
      blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/vo/ExpenseWarehouseTransitMonthVO.java
  21. 14
      blade-service-api/logpm-warehouse-api/src/main/java/com/logpm/warehouse/entity/WarehouseWaybillEntity.java
  22. 28
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/feign/BasicdataWarehouseClient.java
  23. 1
      blade-service/logpm-distribution/src/main/java/com/logpm/distribution/api/DistributionStockupAppController.java
  24. 3
      blade-service/logpm-distribution/src/main/java/com/logpm/distribution/controller/DistributionSignforController.java
  25. 27
      blade-service/logpm-distribution/src/main/java/com/logpm/distribution/feign/QualityDeliverClient.java
  26. 15
      blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionSignforServiceImpl.java
  27. 22
      blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistrilbutionBillLadingServiceImpl.java
  28. 5
      blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/QualityDeliverServiceImpl.java
  29. 13
      blade-service/logpm-report/src/main/java/com/logpm/report/mapper/WarehouseIndexMapper.xml
  30. 5
      blade-service/logpm-statisticsdata/pom.xml
  31. 97
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseDispatchWarehouseMonthController.java
  32. 157
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseOrderWarehouseMonthController.java
  33. 156
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseOrderWarehouseTotalController.java
  34. 125
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseWarehouseController.java
  35. 78
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseWarehouseDayController.java
  36. 156
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseWarehouseMonthController.java
  37. 72
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/MerchantStatisticsController.java
  38. 133
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/job/ExpenseJob.java
  39. 8
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/listener/mq/WaybillCheckListener.java
  40. 11
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseOrderWarehouseTotalMapper.java
  41. 45
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseOrderWarehouseTotalMapper.xml
  42. 3
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehouseDayMapper.java
  43. 108
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehouseDayMapper.xml
  44. 12
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehouseMonthMapper.java
  45. 14
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehouseMonthMapper.xml
  46. 37
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehousePackageDayMapper.java
  47. 12
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehousePackageDayMapper.xml
  48. 3
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/StatisticsOrderInfoMapper.java
  49. 176
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/StatisticsOrderInfoMapper.xml
  50. 17
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/query/ExpenseWarehouseDayQuery.java
  51. 17
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/query/ExpenseWarehouseMonthQuery.java
  52. 20
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/query/ExpenseWarehouseOrderQuery.java
  53. 11
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/query/ExpenseWarehousePackageDayQuery.java
  54. 11
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/query/ExpenseWarehouseTransitMonthQuery.java
  55. 30
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/IExpenseOrderWarehouseTotalService.java
  56. 34
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/IExpenseWarehouseDayService.java
  57. 26
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/IExpenseWarehouseMonthService.java
  58. 37
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/IExpenseWarehousePackageDayService.java
  59. 6
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/IStatisticsOrderInfoService.java
  60. 40
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/impl/ExpenseOrderWarehouseTotalServiceImpl.java
  61. 32
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/impl/ExpenseWarehouseDayServiceImpl.java
  62. 31
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/impl/ExpenseWarehouseMonthServiceImpl.java
  63. 43
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/impl/ExpenseWarehousePackageDayServiceImpl.java
  64. 791
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/impl/StatisticsOrderInfoServiceImpl.java
  65. 174
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseWarehouseDayVO.java
  66. 124
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseWarehouseMonthVO.java
  67. 111
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseWarehouseOrderVO.java
  68. 14
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseWarehousePackageDayVO.java
  69. 34
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseWarehouseTransitMonthVO.java
  70. 1
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/StatisticsPackageFeeInfoVO.java
  71. 10
      blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/wrapper/ExpenseOrderWarehouseTotalWrapper.java
  72. 161
      blade-service/logpm-trunkline/src/main/java/com/logpm/trunkline/mq/waybil/StatusLogListener.java
  73. 19
      blade-service/logpm-trunkline/src/main/java/com/logpm/trunkline/service/impl/TrunklineWaybillTrackServiceImpl.java

10
blade-biz-common/src/main/java/org/springblade/common/constant/broadcast/FanoutConstants.java

@ -322,6 +322,11 @@ public abstract class FanoutConstants {
interface QUEUE {
String REPORT = "fanout.distribution.DeliveryAndrecheck.report" + ModuleNameConstant.DEVAUTH;
String waybillStatusLog = "fanout.distribution.DeliveryAndrecheck.waybill.log" + ModuleNameConstant.DEVAUTH;
}
}
@ -396,6 +401,11 @@ public abstract class FanoutConstants {
interface QUEUE {
String REPORT = "fanout.BillSignReview.billsignreview.report" + ModuleNameConstant.DEVAUTH;
//增加运单状态的变更日志
String waybillStatusLog = "fanout.BillSignReview.waybill.log" + ModuleNameConstant.DEVAUTH;
}
}

8
blade-biz-common/src/main/java/org/springblade/common/model/DistributionSignforVO.java

@ -3,6 +3,7 @@ package org.springblade.common.model;
import lombok.Data;
import java.io.Serializable;
import java.util.Date;
import java.util.List;
/**
@ -40,6 +41,13 @@ public class DistributionSignforVO implements Serializable {
* 签收车次
*/
private String trainNumber;
/**
* 配送时间
*/
private Date deliveryTime;
/**
* 预约单ID
*/

11
blade-biz-common/src/main/java/org/springblade/common/model/PackageData.java

@ -8,6 +8,7 @@ import org.springblade.common.enums.PackageTypeEnums;
import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;
/**
* 提送数据
@ -138,4 +139,14 @@ public class PackageData implements Serializable {
*/
private String systemType ;
/**
* 签收时间
*/
private Date signTime;
/**
* 签收人
*/
private String signUser;//签收人
}

23
blade-biz-common/src/main/java/org/springblade/common/model/workNode/PickUpByScanVO.java

@ -3,6 +3,7 @@ package org.springblade.common.model.workNode;
import lombok.Data;
import org.springblade.common.model.PackageData;
import java.util.Date;
import java.util.List;
@Data
@ -12,6 +13,28 @@ public class PickUpByScanVO {
* 自提单号
*/
private String pickupBatch;
//
// /**
// * 车次号
// */
// private String trainNumber;
/**
* 车牌号
*/
private String carNumber;
/**
* 司机名称
*/
private String driverName;
/**
* 配送时间
*/
private Date deliveryTime;
/**
* 自提明细数据

3
blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/feign/IBasicdataWarehouseClient.java

@ -152,6 +152,9 @@ public interface IBasicdataWarehouseClient {
@GetMapping(API_PREFIX + "/findAllList")
List<BasicdataWarehouseEntity> findAllList();
@GetMapping(API_PREFIX + "/findAllListBusinessLine")
List<BasicdataWarehouseEntity> findAllListBusinessLine();
@GetMapping(API_PREFIX + "/findWarehousesByIds")
List<BasicdataWarehouseEntity> findWarehousesByIds(@RequestParam("ids") List<Long> ids);

6
blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/feign/IBasicdataWarehouseClientFallback.java

@ -120,6 +120,12 @@ public class IBasicdataWarehouseClientFallback implements IBasicdataWarehouseCli
throw feignException;
}
@Override
public List<BasicdataWarehouseEntity> findAllListBusinessLine() {
log.error("调用logpm-basicdata-api接口失败:findAllListBusinessLine ");
throw feignException;
}
@Override
public List<BasicdataWarehouseEntity> findWarehousesByIds(List<Long> ids) {
log.error("调用logpm-basicdata-api接口失败:findWarehousesByIds {} ", ids);

16
blade-service-api/logpm-distribution-api/src/main/java/com/logpm/distribution/entity/QualityDeliverEntity.java

@ -660,19 +660,9 @@ public class QualityDeliverEntity extends TenantEntity {
@ApiModelProperty(value = "其它成本")
private String otherCost;
/**
* 仓库租用成本
* 仓库成本
*/
@ApiModelProperty(value = "仓库租用成本")
private String warehouseRentalCost;
/**
* 仓库临时周转成本
*/
@ApiModelProperty(value = "仓库临时周转成本")
private String warehouseTurnoverCost;
/**
* 仓库干仓配成本
*/
@ApiModelProperty(value = "仓库干仓配成本")
private String warehouseDeliveryCost;
@ApiModelProperty(value = "仓库成本")
private BigDecimal warehouseCost;
}

7
blade-service-api/logpm-distribution-api/src/main/java/com/logpm/distribution/feign/IQualityDeliverClient.java

@ -20,9 +20,13 @@ import com.logpm.distribution.entity.QualityDeliverEntity;
import org.springblade.common.constant.ModuleNameConstant;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestParam;
import java.math.BigDecimal;
import java.util.List;
import java.util.Map;
/**
* 配送统计明细表feign
@ -46,4 +50,7 @@ public interface IQualityDeliverClient {
@GetMapping(API_PREFIX + "/findSignListByDate")
List<QualityDeliverEntity> findSignListByDate(@RequestParam("signTime") String signTime);
@PostMapping(API_PREFIX + "/updateWarehouseCost")
void updateWarehouseCost(@RequestBody Map<Long, BigDecimal> packageCostMap);
}

7
blade-service-api/logpm-statisticsdata-api/pom.xml

@ -14,5 +14,12 @@
<artifactId>logpm-statisticsdata-api</artifactId>
<version>3.2.0.RELEASE</version>
<dependencies>
<dependency>
<groupId>org.springblade</groupId>
<artifactId>blade-starter-excel</artifactId>
</dependency>
</dependencies>
</project>

4
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/dto/ExpenseOrderWarehouseTotalDTO.java → blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/dto/ExpenseWarehouseOrderDTO.java

@ -16,7 +16,7 @@
*/
package com.logpm.statistics.dto;
import com.logpm.statistics.entity.ExpenseOrderWarehouseTotalEntity;
import com.logpm.statistics.entity.ExpenseWarehouseOrderEntity;
import lombok.Data;
import lombok.EqualsAndHashCode;
@ -28,7 +28,7 @@ import lombok.EqualsAndHashCode;
*/
@Data
@EqualsAndHashCode(callSuper = true)
public class ExpenseOrderWarehouseTotalDTO extends ExpenseOrderWarehouseTotalEntity {
public class ExpenseWarehouseOrderDTO extends ExpenseWarehouseOrderEntity {
private static final long serialVersionUID = 1L;
}

5
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/dto/MerchantStatisticsDTO.java

@ -24,7 +24,12 @@ public class MerchantStatisticsDTO implements Serializable {
private Integer confirmStatisticsOrder;//对账状态 0 1
private List<Long> reconciliationOrderIds;
private List<Long> orderInfoIds;
/**
* 运单ID集合
*/
private List<Long> waybillIds;
private Long balanceOrderInfoId;

103
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseOrderWarehouseTotalEntity.java

@ -1,103 +0,0 @@
package com.logpm.statistics.entity;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.tenant.mp.TenantEntity;
/**
* 订单总仓储成本明细
*
* @author zqb
* @create 2024-07-17 11:32:30
*/
@Data
@TableName("logpm_expense_order_warehouse_total")
@ApiModel(value = "ExpenseOrderWarehouseTotal对象", description = "订单总仓储成本明细")
@EqualsAndHashCode(callSuper = true)
public class ExpenseOrderWarehouseTotalEntity extends TenantEntity {
private static final long serialVersionUID = 1L;
/**
* 目的仓
*/
@ApiModelProperty(value = "目的仓")
private String warehouseName;
/**
* 订单编号
*/
@ApiModelProperty(value = "订单编号")
private String orderCode;
/**
* 运单编号
*/
@ApiModelProperty(value = "运单编号")
private String shipmentNumber;
/**
* 收货单位
*/
@ApiModelProperty(value = "收货单位")
private String receivingUnit;
/**
* 发货单位
*/
@ApiModelProperty(value = "发货单位")
private String shippingUnit;
/**
* 运单类型
*/
@ApiModelProperty(value = "运单类型")
private String shipmenttype;
/**
* 服务类型
*/
@ApiModelProperty(value = "服务类型")
private String servicetype;
/**
* 总件数
*/
@ApiModelProperty(value = "总件数")
private String totalQuantity;
/**
* 发站仓
*/
@ApiModelProperty(value = "发站仓")
private String originWarehouse;
/**
* 代入库仓件数
*/
@ApiModelProperty(value = "代入库仓件数")
private String consignmentInQuantity;
/**
* 代入库总成本
*/
@ApiModelProperty(value = "代入库总成本")
private String consignmentInTotalCost;
/**
* 代出库仓件数
*/
@ApiModelProperty(value = "代出库仓件数")
private String consignmentOutQuantity;
/**
* 代出库成本
*/
@ApiModelProperty(value = "代出库成本")
private String consignmentOutTotalCost;
/**
* 代作业成本
*/
@ApiModelProperty(value = "代作业成本")
private String contractedOperaCost;
/**
* 仓租成本
*/
@ApiModelProperty(value = "仓租成本")
private String warehouseRentalCost;
/**
* 仓储成本
*/
@ApiModelProperty(value = "仓储成本")
private String warehousingCost;
}

148
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseWarehouseDayEntity.java

@ -16,6 +16,8 @@
*/
package com.logpm.statistics.entity;
import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
@ -23,6 +25,8 @@ import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.tenant.mp.TenantEntity;
import java.math.BigDecimal;
/**
* 日仓储成本统计表 实体类
*
@ -34,139 +38,163 @@ import org.springblade.core.tenant.mp.TenantEntity;
@ApiModel(value = "ExpenseWarehouseDay对象", description = "日仓储成本统计表")
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseDayEntity extends TenantEntity {
/**
* 统计年
*/
@ApiModelProperty(value = "统计年")
@ExcelIgnore
private Integer statisticalYear;
/**
* 统计月
*/
@ApiModelProperty(value = "统计月")
@ExcelIgnore
private Integer statisticalMonth;
/**
* 统计日
*/
@ApiModelProperty(value = "统计日")
@ExcelIgnore
private Integer statisticalDay;
/**
* 目的仓
*/
@ApiModelProperty(value = "目的仓")
@ExcelProperty("目的仓")
private String warehouseName;
/**
* 成本结算时间-
* 日期
*/
@ApiModelProperty(value = "成本结算时间-年")
private String costSettlementYear;
@ApiModelProperty(value = "日期")
@ExcelProperty("日期")
private String statisticalTime;
/**
* 成本结算时间-
* 当月天数
*/
@ApiModelProperty(value = "成本结算时间-月")
private String costSettlementMonth;
@ApiModelProperty(value = "当月天数")
@ExcelIgnore
private Integer dayNumber;
/**
* 成本结算时间-
* 事业线
*/
@ApiModelProperty(value = "成本结算时间-日")
private String costSettlementDay;
/**
* 成本结算时间
*/
@ApiModelProperty(value = "成本结算时间")
private String costSettlement;
@ApiModelProperty(value = "事业线")
@ExcelIgnore
private String businessUnit;
/**
* 仓库总面积
*/
@ApiModelProperty(value = "仓库总面积(㎡)")
private String totalArea;
@ExcelProperty("仓库总面积")
private BigDecimal totalArea;
/**
* 仓库租金
*/
@ApiModelProperty(value = "仓库租金")
@ExcelProperty("仓库租金")
private BigDecimal rent;
/**
* 仓库月租金
*/
@ApiModelProperty(value = "仓库日租金")
private String monthlyRent;
@ExcelProperty("仓库日租金")
private BigDecimal dailyRent;
/**
* 出库总件数
*/
@ApiModelProperty(value = "出库总件数")
private String totalQuantityIssued;
@ExcelProperty("出库总件数")
private Integer totalOutQuantity;
/**
* 客户租用面积
*/
@ApiModelProperty(value = "客户租用面积(㎡)")
private String customerLeasedArea;
@ExcelProperty("客户租用面积")
private BigDecimal customerRentalArea;
/**
* 客户月租金
*/
@ApiModelProperty(value = "客户日租金")
private String customerMonthlyRent;
@ApiModelProperty(value = "客户租用月租金")
@ExcelProperty("客户租用月租金")
private BigDecimal customerMonthlyRent;
/**
* 客户日租金
*/
@ApiModelProperty(value = "客户租用日租金")
@ExcelProperty("客户租用日租金")
private BigDecimal customerDailyRent;
/**
* 租用出库件数
*/
@ApiModelProperty(value = "租用出库件数")
private String rentedItemsDispatchedQuantity;
@ApiModelProperty(value = "客户租用出库件数")
@ExcelProperty("客户租用出库件数")
private Integer customerRentalOutQuantity;
/**
* 客户租用单件成本
*/
@ApiModelProperty(value = "客户租用单件成本")
private String customerRentedItemCostPerUnit;
@ExcelProperty("客户租用单件成本")
private BigDecimal customerRentalUnitCost;
/**
* 客户租用总成本
*/
@ApiModelProperty(value = "客户租用总成本")
private String customerTotalLeasingCost;
@ExcelProperty("客户租用总成本")
private BigDecimal customerTotalRentalCost;
/**
* 临时周转面积
*/
@ApiModelProperty(value = "临时周转面积")
private String temporaryTurnoverArea;
@ExcelProperty("临时周转面积")
private BigDecimal temporaryTurnoverArea;
/**
* 临时周转件数
*/
@ApiModelProperty(value = "临时周转件数")
private String temporaryTurnoverQuantity;
@ExcelProperty("临时周转件数")
private Integer temporaryTurnoverQuantity;
/**
* 临时周转单件成本
*/
@ApiModelProperty(value = "临时周转单件成本")
private String temporaryTurnoverCostPerItem;
@ExcelProperty("临时周转单件成本")
private BigDecimal temporaryTurnoverUnitCost;
/**
* 临时周转总成本
*/
@ApiModelProperty(value = "临时周转总成本")
private String totalTemporaryTurnoverCost;
@ExcelProperty("临时周转总成本")
private BigDecimal temporaryTurnoverTotalCost;
/**
* 干仓配仓储面积
*/
@ApiModelProperty(value = "干仓配仓储面积")
private String drWareDisArea;
@ExcelProperty("干仓配仓储面积")
private BigDecimal drWareDisArea;
/**
* 干仓配件数
*/
@ApiModelProperty(value = "干仓配件数")
private String drWareDisNumber;
@ExcelProperty("干仓配件数")
private Integer drWareDisNumber;
/**
* 干仓配单件成本
*/
@ApiModelProperty(value = "干仓配单件成本")
private String drWareDisCostPerUnit;
@ExcelProperty("干仓配单件成本")
private BigDecimal drWareDisCostPerUnit;
/**
* 干仓配仓储总成本
*/
@ApiModelProperty(value = "干仓配仓储总成本")
private String drWareDisTotalCost;
/**
* 代入库件数
*/
@ApiModelProperty(value = "代入库件数")
private String consignmentStorage;
@ExcelProperty("干仓配仓储总成本")
private BigDecimal drWareDisTotalCost;
/**
* 代入库总成本
* 仓库租赁总成本
*/
@ApiModelProperty(value = "代入库总成本")
private String totalCostOfConsignmentStorage;
/**
* 代出库件数
*/
@ApiModelProperty(value = "代出库件数")
private String consignmentWithdrawal;
/**
* 代出库总成本
*/
@ApiModelProperty(value = "代出库总成本")
private String totalCostOfConsignmentWithdrawal;
/**
* 代作业总成本
*/
@ApiModelProperty(value = "代作业总成本")
private String totalCostOfAgencyOperations;
/**
* 仓储总成本
*/
@ApiModelProperty(value = "仓储总成本")
private String totalWarehouseCost;
@ApiModelProperty(value = "仓库租赁总成本")
@ExcelProperty("仓库租赁总成本")
private BigDecimal warehouseCost;
}

117
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseWarehouseMonthEntity.java

@ -1,5 +1,7 @@
package com.logpm.statistics.entity;
import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
@ -7,6 +9,8 @@ import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.tenant.mp.TenantEntity;
import java.math.BigDecimal;
/**
* 月度仓储成本统计表
*
@ -18,126 +22,115 @@ import org.springblade.core.tenant.mp.TenantEntity;
@ApiModel(value = "ExpenseWarehouseMonth对象", description = "月度仓储成本统计表")
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseMonthEntity extends TenantEntity {
private static final long serialVersionUID = 1L;
/**
* 目的仓
* 统计年
*/
@ApiModelProperty(value = "目的仓")
private String warehouseName;
@ApiModelProperty(value = "统计年")
@ExcelIgnore
private Integer statisticalYear;
/**
* 成本结算时间-
* 统计月
*/
@ApiModelProperty(value = "成本结算时间-年")
private String costSettlementYear;
@ApiModelProperty(value = "统计月")
@ExcelIgnore
private Integer statisticalMonth;
/**
* 成本结算时间-
* 日期
*/
@ApiModelProperty(value = "成本结算时间-月")
private String costSettlementMonth;
@ApiModelProperty(value = "日期")
@ExcelIgnore
private String statisticalTime;
/**
* 成本结算时间
* 事业线
*/
@ApiModelProperty(value = "成本结算时间")
private String costSettlement;
@ApiModelProperty(value = "事业线")
@ExcelIgnore
private String businessUnit;
/**
* 库总面积
* 目的
*/
@ApiModelProperty(value = "仓库总面积(㎡)")
private String totalArea;
@ApiModelProperty(value = "目的仓")
@ExcelProperty("目的仓")
private String warehouseName;
/**
* 仓库月租金
*/
@ApiModelProperty(value = "仓库月租金")
private String monthlyRent;
@ExcelProperty("仓库月租金")
private BigDecimal monthlyRent;
/**
* 出库总件数
*/
@ApiModelProperty(value = "出库总件数")
private String totalQuantityIssued;
/**
* 客户租用面积
*/
@ApiModelProperty(value = "客户租用面积(㎡)")
private String customerLeasedArea;
@ExcelProperty("出库总件数")
private Integer totalOutQuantity;
/**
* 客户月租金
*/
@ApiModelProperty(value = "客户月租金")
private String customerMonthlyRent;
@ApiModelProperty(value = "客户租用月租金")
@ExcelProperty("客户租用月租金")
private BigDecimal customerMonthlyRent;
/**
* 租用出库件数
*/
@ApiModelProperty(value = "租用出库件数")
private String rentedItemsDispatchedQuantity;
@ApiModelProperty(value = "客户租用出库件数")
@ExcelProperty("客户租用出库件数")
private Integer customerRentalOutQuantity;
/**
* 客户租用单件成本
*/
@ApiModelProperty(value = "客户租用单件成本")
private String customerRentedItemCostPerUnit;
@ExcelProperty("客户租用单件成本")
private BigDecimal customerRentalUnitCost;
/**
* 客户租用总成本
*/
@ApiModelProperty(value = "客户租用总成本")
private String customerTotalLeasingCost;
/**
* 临时周转面积
*/
@ApiModelProperty(value = "临时周转面积")
private String temporaryTurnoverArea;
@ExcelProperty("客户租用总成本")
private BigDecimal customerTotalRentalCost;
/**
* 临时周转件数
*/
@ApiModelProperty(value = "临时周转件数")
private String temporaryTurnoverQuantity;
@ExcelProperty("临时周转件数")
private Integer temporaryTurnoverQuantity;
/**
* 临时周转单件成本
*/
@ApiModelProperty(value = "临时周转单件成本")
private String temporaryTurnoverCostPerItem;
@ExcelProperty("临时周转单件成本")
private BigDecimal temporaryTurnoverUnitCost;
/**
* 临时周转总成本
*/
@ApiModelProperty(value = "临时周转总成本")
private String totalTemporaryTurnoverCost;
/**
* 干仓配仓储面积
*/
@ApiModelProperty(value = "干仓配仓储面积")
private String drWareDisArea;
@ExcelProperty("临时周转总成本")
private BigDecimal temporaryTurnoverTotalCost;
/**
* 干仓配件数
*/
@ApiModelProperty(value = "干仓配件数")
private String drWareDisNumber;
@ExcelProperty("干仓配件数")
private Integer drWareDisNumber;
/**
* 干仓配单件成本
*/
@ApiModelProperty(value = "干仓配单件成本")
private String drWareDisCostPerUnit;
@ExcelProperty("干仓配单件成本")
private BigDecimal drWareDisCostPerUnit;
/**
* 干仓配仓储总成本
*/
@ApiModelProperty(value = "干仓配仓储总成本")
private String drWareDisTotalCost;
/**
* 代入库总成本
*/
@ApiModelProperty(value = "代入库总成本")
private String totalCostOfConsignmentStorage;
/**
* 代出库总成本
*/
@ApiModelProperty(value = "代出库总成本")
private String totalCostOfConsignmentWithdrawal;
/**
* 代作业总成本
*/
@ApiModelProperty(value = "代作业总成本")
private String totalCostOfAgencyOperations;
@ExcelProperty("干仓配仓储总成本")
private BigDecimal drWareDisTotalCost;
/**
* 总成本
* 仓库租赁总成本
*/
@ApiModelProperty(value = "仓储总成本")
private String totalWarehouseCost;
@ApiModelProperty(value = "仓库租赁总成本")
@ExcelProperty("仓库租赁总成本")
private BigDecimal warehouseCost;
}

89
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseWarehouseOrderEntity.java

@ -0,0 +1,89 @@
package com.logpm.statistics.entity;
import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.tenant.mp.TenantEntity;
import java.math.BigDecimal;
/**
* 订单仓储成本报表
*
* @author zqb
* @create 2024-07-17 11:32:30
*/
@Data
@TableName("logpm_expense_warehouse_order")
@ApiModel(value = "ExpenseWarehouseOrderEntity对象", description = "订单仓储成本报表")
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseOrderEntity extends TenantEntity {
private static final long serialVersionUID = 1L;
/**
* 事业线
*/
@ApiModelProperty(value = "事业线")
@ExcelIgnore
private String businessUnit;
/**
* 目的仓
*/
@ApiModelProperty(value = "目的仓")
@ExcelProperty("目的仓")
private String warehouseName;
/**
* 订单编号
*/
@ApiModelProperty(value = "订单编号")
@ExcelProperty("订单编号")
private String orderCode;
/**
* 运单编号
*/
@ApiModelProperty(value = "运单编号")
@ExcelProperty("运单编号")
private String shipmentNumber;
/**
* 收货单位
*/
@ApiModelProperty(value = "收货单位")
@ExcelProperty("收货单位")
private String receivingUnit;
/**
* 发货单位
*/
@ApiModelProperty(value = "发货单位")
@ExcelProperty("发货单位")
private String shippingUnit;
/**
* 发站仓
*/
@ApiModelProperty(value = "发站仓")
@ExcelProperty("发站仓")
private String originWarehouse;
/**
* 订单总件数
*/
@ApiModelProperty(value = "订单总件数")
@ExcelProperty("订单总件数")
private Integer totalNumber;
/**
* 出库件数
*/
@ApiModelProperty(value = "出库件数")
@ExcelProperty("出库件数")
private Integer outNumber;
/**
* 租赁成本
*/
@ApiModelProperty(value = "租赁成本")
@ExcelProperty("租赁成本")
private BigDecimal warehouseRentalCost;
}

121
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseWarehousePackageDayEntity.java

@ -0,0 +1,121 @@
package com.logpm.statistics.entity;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.tenant.mp.TenantEntity;
import java.math.BigDecimal;
/**
* 日包件仓储成本报表
*
* @author zqb
* @create 2024-07-17 11:32:30
*/
@Data
@TableName("logpm_expense_warehouse_package_day")
@ApiModel(value = "ExpenseWarehousePackageEntity对象", description = "日包件仓储成本报表")
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehousePackageDayEntity extends TenantEntity {
private static final long serialVersionUID = 1L;
/**
* 统计年
*/
@ApiModelProperty(value = "统计年")
private Integer statisticalYear;
/**
* 统计月
*/
@ApiModelProperty(value = "统计月")
private Integer statisticalMonth;
/**
* 统计日
*/
@ApiModelProperty(value = "统计日")
private Integer statisticalDay;
/**
* 日期
*/
@ApiModelProperty(value = "日期")
private String statisticalTime;
/**
* 事业线
*/
@ApiModelProperty(value = "事业线")
private String businessUnit;
/**
* 目的仓
*/
@ApiModelProperty(value = "目的仓")
private String warehouseName;
/**
* 品牌
*/
@ApiModelProperty(value = "品牌")
private String brandName;
/**
* 包条码
*/
@ApiModelProperty(value = "包条码")
private String packageCode;
/**
* 包件类型
*/
@ApiModelProperty(value = "包件类型")
private String packageType;
/**
* 订单编号
*/
@ApiModelProperty(value = "订单编号")
private String orderCode;
/**
* 运单编号
*/
@ApiModelProperty(value = "运单编号")
private String shipmentNumber;
/**
* 收货单位
*/
@ApiModelProperty(value = "收货单位")
private String receivingUnit;
/**
* 发货单位
*/
@ApiModelProperty(value = "发货单位")
private String shippingUnit;
/**
* 成本类型
*/
@ApiModelProperty(value = "成本类型")
private String expenseType;
/**
* 中转仓
*/
@ApiModelProperty(value = "中转仓")
private String transitWarehouseName;
/**
* 配送类型
*/
@ApiModelProperty(value = "配送类型")
private String dispatchType;
/**
* 发站仓
*/
@ApiModelProperty(value = "发站仓")
private String originWarehouse;
/**
* 件数
*/
@ApiModelProperty(value = "件数")
private Integer number;
/**
* 成本
*/
@ApiModelProperty(value = "成本")
private BigDecimal cost;
}

80
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/ExpenseWarehouseTransitMonthEntity.java

@ -0,0 +1,80 @@
package com.logpm.statistics.entity;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.tenant.mp.TenantEntity;
import java.math.BigDecimal;
/**
* 中转仓月度成本报表
*
* @author zqb
* @create 2024-07-17 11:32:30
*/
@Data
@TableName("logpm_expense_warehouse_transit_month")
@ApiModel(value = "ExpenseWarehouseTransitMonthEntity对象", description = "中转仓月度成本报表")
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseTransitMonthEntity extends TenantEntity {
private static final long serialVersionUID = 1L;
/**
* 统计年
*/
@ApiModelProperty(value = "统计年")
private Integer statisticalYear;
/**
* 统计月
*/
@ApiModelProperty(value = "统计月")
private Integer statisticalMonth;
/**
* 日期
*/
@ApiModelProperty(value = "日期")
private String statisticalTime;
/**
* 事业线
*/
@ApiModelProperty(value = "事业线")
private String businessUnit;
/**
* 中转仓
*/
@ApiModelProperty(value = "中转仓")
private String transitWarehouseName;
/**
* 目的仓
*/
@ApiModelProperty(value = "目的仓")
private String warehouseName;
/**
* 中转入库件数
*/
@ApiModelProperty(value = "中转入库件数")
private Integer inNumber;
/**
* 中转入库收入
*/
@ApiModelProperty(value = "中转入库收入")
private BigDecimal inCost;
/**
* 中转出库件数
*/
@ApiModelProperty(value = "中转出库件数")
private Integer outNumber;
/**
* 中转出库收入
*/
@ApiModelProperty(value = "中转出库收入")
private BigDecimal outCost;
/**
* 中转总收入
*/
@ApiModelProperty(value = "中转总收入")
private BigDecimal totalCost;
}

30
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/StatisticsDistributionPackageEntity.java

@ -118,4 +118,34 @@ public class StatisticsDistributionPackageEntity extends TenantEntity {
private Integer systemDeliveryChargeType;
private Integer deliveryChargeType;
/**
* 上楼层数
*/
@ApiModelProperty(value = "上楼层数")
private BigDecimal deliveryUpfloor;
/**
* 是否装卸
*/
@ApiModelProperty(value = "是否装卸")
private Integer deliveryLoading;
/**
* 是否分货
*/
@ApiModelProperty(value = "是否分货")
private Integer deliverySorting;
/**
* 平移米数
*/
@ApiModelProperty(value = "平移米数")
private BigDecimal deliveryMove;
/**
* 专车费
*/
@ApiModelProperty(value = "专车费")
private BigDecimal dedicatedVehicleFee;
}

9
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/entity/StatisticsOrderInfoEntity.java

@ -69,11 +69,16 @@ public class StatisticsOrderInfoEntity extends TenantEntity {
@ApiModelProperty(value = "服务类型")
private Integer typeService;
@ApiModelProperty(value = "签收状态")
private Integer signStatus;// 签收状态 0未签收 1部分签收 2已签收
@ApiModelProperty(value = "签收状态 0未签收 1部分签收 2已签收")
private Integer signStatus;
@ApiModelProperty(value = "签收时间")
private Date signDate;
@ApiModelProperty(value = "复核状态 0未复核 1部分复核 2已复核")
private Integer reViewStatus;
@ApiModelProperty(value = "复核时间")
private Date reViewDate;
@ApiModelProperty(value = "计算金额状态 0否 1是")
private Integer syncFeeStatus;
@ApiModelProperty(value = "计算金额时间")

79
blade-service-api/logpm-statisticsdata-api/src/main/java/com/logpm/statistics/vo/ExpenseWarehouseTransitMonthVO.java

@ -0,0 +1,79 @@
package com.logpm.statistics.vo;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.tenant.mp.TenantEntity;
import java.math.BigDecimal;
/**
* 中转仓月度成本报表
*
* @author zqb
* @create 2024-07-17 11:32:30
*/
@Data
@ApiModel(value = "ExpenseWarehouseTransitMonthEntity对象", description = "中转仓月度成本报表")
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseTransitMonthVO extends TenantEntity {
private static final long serialVersionUID = 1L;
/**
* 统计年
*/
@ApiModelProperty(value = "统计年")
private Integer statisticalYear;
/**
* 统计月
*/
@ApiModelProperty(value = "统计月")
private Integer statisticalMonth;
/**
* 日期
*/
@ApiModelProperty(value = "日期")
private String statisticalTime;
/**
* 事业线
*/
@ApiModelProperty(value = "事业线")
private String businessUnit;
/**
* 中转仓
*/
@ApiModelProperty(value = "中转仓")
private String transitWarehouseName;
/**
* 目的仓
*/
@ApiModelProperty(value = "目的仓")
private String warehouseName;
/**
* 中转入库件数
*/
@ApiModelProperty(value = "中转入库件数")
private Integer inNumber;
/**
* 中转入库收入
*/
@ApiModelProperty(value = "中转入库收入")
private BigDecimal inCost;
/**
* 中转出库件数
*/
@ApiModelProperty(value = "中转出库件数")
private Integer outNumber;
/**
* 中转出库收入
*/
@ApiModelProperty(value = "中转出库收入")
private BigDecimal outCost;
/**
* 中转总收入
*/
@ApiModelProperty(value = "中转总收入")
private BigDecimal totalCost;
}

14
blade-service-api/logpm-warehouse-api/src/main/java/com/logpm/warehouse/entity/WarehouseWaybillEntity.java

@ -547,6 +547,20 @@ public class WarehouseWaybillEntity extends TenantEntity {
@ApiModelProperty(value = "文员复核时间 ")
private Date signCheckTime;
/**
*付款状态(null) 10 未付款 20 部分付款 30 已付款
*/
@ApiModelProperty(value = "付款状态")
private String payStatus;
/**
* 结算状态nul 10未结算 20 部分结算 30 已结算
*/
@ApiModelProperty(value = "结算状态")
private String settlementStatus;

28
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/feign/BasicdataWarehouseClient.java

@ -268,6 +268,34 @@ public class BasicdataWarehouseClient implements IBasicdataWarehouseClient {
);
}
@Override
public List<BasicdataWarehouseEntity> findAllListBusinessLine() {
List<BasicdataWarehouseEntity> list = warehouseWarehouseService.list(Wrappers.<BasicdataWarehouseEntity>lambdaQuery()
.eq(BasicdataWarehouseEntity::getEnableStatus, 2)
);
if(CollUtil.isNotEmpty(list)){
for (BasicdataWarehouseEntity warehouseEntity : list) {
Long department = warehouseEntity.getDepartment();
if(ObjectUtil.isNotNull(department)){
Dept dept = deptClient.findEntityById(department);
if(ObjectUtil.isNotEmpty(dept)){
Integer deptCategory = dept.getDeptCategory();
if(NumberUtil.equals(deptCategory,2)){
warehouseEntity.setBusinessLine(dept.getDeptName());
} else {
Long parentId = dept.getParentId();
Dept parentDept = deptClient.findEntityById(parentId);
if(ObjectUtil.isNotEmpty(parentDept)){
warehouseEntity.setBusinessLine(parentDept.getDeptName());
}
}
}
}
}
}
return list;
}
@Override
public List<BasicdataWarehouseEntity> findWarehousesByIds(List<Long> ids) {
if(CollUtil.isNotEmpty(ids)){

1
blade-service/logpm-distribution/src/main/java/com/logpm/distribution/api/DistributionStockupAppController.java

@ -754,7 +754,6 @@ public class DistributionStockupAppController extends BladeController {
}
//todo 这里代码没有写完 等TJJ 和CYZ 空了来写
@ResponseBody
@PostMapping("/updateStockup")
@ApiOperationSupport(order = 1)

3
blade-service/logpm-distribution/src/main/java/com/logpm/distribution/controller/DistributionSignforController.java

@ -381,9 +381,6 @@ public class DistributionSignforController extends BladeController {
distributionSignforService.updateSign(distributionSignforDTO);
distributionDeliveryListService.maintenanceDeliveryInfo(distributionSignfor.getDeliveryId());
distributionStockupInfoService.maintenanceStockUp(distributionSignfor.getReservationId(),1);
}
// return R.status(distributionSignforService.updateById(distributionSignfor));
return r;

27
blade-service/logpm-distribution/src/main/java/com/logpm/distribution/feign/QualityDeliverClient.java

@ -16,6 +16,7 @@
*/
package com.logpm.distribution.feign;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.date.DateTime;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.util.StrUtil;
@ -23,11 +24,15 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.logpm.distribution.entity.QualityDeliverEntity;
import com.logpm.distribution.service.IQualityDeliverService;
import io.prometheus.client.CollectorRegistry;
import lombok.AllArgsConstructor;
import org.springframework.web.bind.annotation.RestController;
import springfox.documentation.annotations.ApiIgnore;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
/**
* 通知提货记录 Feign实现类
@ -41,6 +46,7 @@ import java.util.List;
public class QualityDeliverClient implements IQualityDeliverClient {
private final IQualityDeliverService qualityDeliverService;
private final CollectorRegistry collectorRegistry;
@Override
@ -52,9 +58,24 @@ public class QualityDeliverClient implements IQualityDeliverClient {
DateTime dayStart = DateUtil.beginOfDay(dateTime);
DateTime dayEnd = DateUtil.endOfDay(dateTime);
LambdaQueryWrapper<QualityDeliverEntity> wrapper = Wrappers.<QualityDeliverEntity>lambdaQuery();
wrapper.ge(QualityDeliverEntity::getSignTime, dayStart);
wrapper.le(QualityDeliverEntity::getSignTime, dayEnd);
// 本月签收包件
wrapper.ge(QualityDeliverEntity::getReviewTime, dayStart);
wrapper.le(QualityDeliverEntity::getReviewTime, dayEnd);
return qualityDeliverService.list(wrapper);
}
@Override
public void updateWarehouseCost(Map<Long, BigDecimal> packageCostMap) {
if(CollUtil.isNotEmpty(packageCostMap)){
List<QualityDeliverEntity> list = new ArrayList<>();
for (Map.Entry<Long, BigDecimal> entry : packageCostMap.entrySet()) {
Long key = entry.getKey();
BigDecimal value = entry.getValue();
QualityDeliverEntity qualityDeliverEntity = new QualityDeliverEntity();
qualityDeliverEntity.setId(key);
qualityDeliverEntity.setWarehouseCost(value);
list.add(qualityDeliverEntity);
}
qualityDeliverService.updateBatchById(list);
}
}
}

15
blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionSignforServiceImpl.java

@ -757,7 +757,7 @@ public class DistributionSignforServiceImpl extends BaseServiceImpl<Distribution
// 推送作业节点数据
NodeFanoutMsg<org.springblade.common.model.DistributionReCheckSignVO> nodeFanoutMsg = buildNodeFanoutMsgByReCheck(reservationEntity);
NodeFanoutMsg<org.springblade.common.model.DistributionReCheckSignVO> nodeFanoutMsg = buildNodeFanoutMsgByReCheck(deliveryListEntity,reservationEntity);
iDistributionNodeWorkService.signForCheck(nodeFanoutMsg, AuthUtil.getUser());
// // 复核作业节点推送
@ -783,7 +783,7 @@ public class DistributionSignforServiceImpl extends BaseServiceImpl<Distribution
distributionPlanLogService.save(distributionPlanLogEntity);
}
private NodeFanoutMsg<org.springblade.common.model.DistributionReCheckSignVO> buildNodeFanoutMsgByReCheck(DistributionReservationEntity reservationEntity) {
private NodeFanoutMsg<org.springblade.common.model.DistributionReCheckSignVO> buildNodeFanoutMsgByReCheck(DistributionDeliveryListEntity deliveryListEntity,DistributionReservationEntity reservationEntity) {
// 查询当前预约单下的定制品和零担签收数据
NodeFanoutMsg<org.springblade.common.model.DistributionReCheckSignVO> nodeFanoutMsg = new NodeFanoutMsg();
@ -798,6 +798,11 @@ public class DistributionSignforServiceImpl extends BaseServiceImpl<Distribution
org.springblade.common.model.DistributionReCheckSignVO distributionLoadVO = new org.springblade.common.model.DistributionReCheckSignVO();
distributionLoadVO.setReservationCode(reservationEntity.getReservationCode());
distributionLoadVO.setDeliveryTime(deliveryListEntity.getCreateTime());
distributionLoadVO.setTrainNumber(deliveryListEntity.getTrainNumber());
distributionLoadVO.setVehicleName(deliveryListEntity.getVehicleName());
distributionLoadVO.setDriverName(deliveryListEntity.getDriverName());
nodeFanoutMsg.setMain(distributionLoadVO);
@ -808,6 +813,8 @@ public class DistributionSignforServiceImpl extends BaseServiceImpl<Distribution
for (DistributionLoadscanEntity distributionLoadscanEntity : list) {
PackageData packageData = new PackageData();
packageData.setSignTime(org.springblade.core.tool.utils.DateUtil.parse(distributionLoadscanEntity.getSigningTime(),"yyyy-mm-dd hh:mm:ss"));
packageData.setSignUser(distributionLoadscanEntity.getSigningUser());
// 不是零担
if (distributionLoadscanEntity.getIsZero() == null || distributionLoadscanEntity.getIsZero() == 0) {
packageData.setPackageCode(distributionLoadscanEntity.getOrderPackageCode());
@ -816,6 +823,8 @@ public class DistributionSignforServiceImpl extends BaseServiceImpl<Distribution
DistributionParcelListEntity distributionParcelListEntity1 = distributionParcelListService.selectByOrderPackageCode(distributionLoadscanEntity.getOrderPackageCode(), distributionLoadscanEntity.getWarehouseId());
if (Func.isNotEmpty(distributionParcelListEntity1)) {
packageData.setBrand(distributionParcelListEntity1.getBrandName());
packageData.setWaybillNumber(distributionParcelListEntity1.getWaybillNumber());
packageData.setOrderCode(distributionParcelListEntity1.getOrderCode());
}
} else {
// 零担
@ -7092,7 +7101,7 @@ public class DistributionSignforServiceImpl extends BaseServiceImpl<Distribution
buildArgsToPushMq(distributionSignfor);
if (isSuccess) {
//整理签收数据回退干线
handletrunklineWaybillSignLog(distributionSignfor.getReservationId());
// handletrunklineWaybillSignLog(distributionSignfor.getReservationId());
this.updateById(distributionSignfor);

22
blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistrilbutionBillLadingServiceImpl.java

@ -3970,7 +3970,7 @@ public class DistrilbutionBillLadingServiceImpl extends BaseServiceImpl<Distrilb
}
}
} catch (Exception e) {
log.error("推送失败:{}", e);
log.error("推送失败:", e);
}
for (DistributionBillLadingScanEntity ladingScanEntity : ladingScanEntities) {
if (ladingScanEntity.getStockArticleId() != null) {
@ -4036,15 +4036,15 @@ public class DistrilbutionBillLadingServiceImpl extends BaseServiceImpl<Distrilb
//释放库存品
updateStock(s, scanEntityList);
}
Integer num = baseMapper.selectBillLadingLoading(billLadingEntity.getId());
Integer num = baseMapper.selectBillLadingLoading(distrilbutionBillLadingEntity.getId());
//自提复核日志
handleDExamineDistributionPlanLog(billLadingEntity, AuthUtil.getUser(), myCurrentWarehouse, num);
handleDExamineDistributionPlanLog(distrilbutionBillLadingEntity, AuthUtil.getUser(), myCurrentWarehouse, num);
// 回传老系统自提数据
sendOldSystem(Long.parseLong(s));
//整理运单信息
handletrunklineWaybillSignLog(billLadingEntity.getId());
// handletrunklineWaybillSignLog(billLadingEntity.getId());
NodeFanoutMsg<PickUpByReCheckVO> nodeFanoutMsg = buildPickUpByReCheckVO(billLadingEntity, ladingScanEntities, myCurrentWarehouse);
NodeFanoutMsg<PickUpByReCheckVO> nodeFanoutMsg = buildPickUpByReCheckVO(distrilbutionBillLadingEntity, ladingScanEntities, myCurrentWarehouse);
iDistributionNodeWorkService.billofladingSignforCheck(nodeFanoutMsg, AuthUtil.getUser());
//推送该自提单的包件运单信息
@ -4165,13 +4165,17 @@ public class DistrilbutionBillLadingServiceImpl extends BaseServiceImpl<Distrilb
nodeFanoutMsg.setTenantId(myCurrentWarehouse.getTenantId());
PickUpByReCheckVO pickUpByReCheckVO = new PickUpByReCheckVO();
pickUpByReCheckVO.setPickupBatch(billLadingEntity.getPickupBatch());
pickUpByReCheckVO.setCarNumber(billLadingEntity.getPickUpPlate());
pickUpByReCheckVO.setDriverName(billLadingEntity.getConsignee());
pickUpByReCheckVO.setDeliveryTime(billLadingEntity.getPickUpTime());
List<PackageData> packageDataList = new ArrayList<>();
pickUpByReCheckVO.setPackageDataList(packageDataList);
ladingScanEntities.forEach(t -> {
PackageData packageData = new PackageData();
packageData.setSignUser(t.getScanUser());
packageData.setSignTime(t.getCreateTime());
if ("1".equals(t.getMaterialType())) {
// 库存
Long stockListId = t.getStockListId();
@ -4184,10 +4188,16 @@ public class DistrilbutionBillLadingServiceImpl extends BaseServiceImpl<Distrilb
packageData.setMaterialCode(byId.getCargoNumber());
packageData.setNumber(t.getQuantity());
packageData.setPackageType(PackageTypeEnums.INV);
}
} else if ("2".equals(t.getMaterialType())) {
//定制品
DistributionParcelListEntity byId = distributionParcelListService.getById(t.getParcelListId());
if (Func.isNotEmpty(byId)) {
packageData.setOrderCode(byId.getOrderCode());
packageData.setWaybillNumber(byId.getWaybillNumber());
}
packageData.setPackageCode(t.getPacketBarCode());
packageData.setNumber(1);
packageData.setPackageType(PackageTypeEnums.CMP);

5
blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/QualityDeliverServiceImpl.java

@ -218,7 +218,7 @@ public class QualityDeliverServiceImpl extends BaseServiceImpl<QualityDeliverMap
yesterday = DateUtil.parseDate(param);
}
// 当前时间对应月分的总天数
Integer days = YearMonth.of(DateUtil.year(yesterday), DateUtil.month(yesterday)).lengthOfMonth();
Integer days = YearMonth.of(DateUtil.year(yesterday), DateUtil.month(yesterday) + 1).lengthOfMonth();
DateTime dayStart = DateUtil.beginOfDay(yesterday);
DateTime dayEnd = DateUtil.endOfDay(yesterday);
LambdaQueryWrapper<QualityDeliverEntity> wrapper = Wrappers.<QualityDeliverEntity>lambdaQuery();
@ -232,9 +232,6 @@ public class QualityDeliverServiceImpl extends BaseServiceImpl<QualityDeliverMap
entities.forEach(entity -> {
QualityDeliverEntity deliverEntity = new QualityDeliverEntity();
deliverEntity.setId(entity.getId());
deliverEntity.setWarehouseRentalCost("0");
deliverEntity.setWarehouseTurnoverCost("0");
deliverEntity.setWarehouseDeliveryCost("0");
deliverEntity.setWarehouseId(entity.getWarehouseId());
deliverEntity.setWarehouseName(entity.getWarehouseName());
// 结算时间

13
blade-service/logpm-report/src/main/java/com/logpm/report/mapper/WarehouseIndexMapper.xml

@ -13,7 +13,7 @@
<if test="param.endDate != null">
and create_time &lt;= #{param.endDate}
</if>
and departure_warehouse_id in
and destination_warehouse_id in
<foreach collection="param.warehouseIds" item="item" open="(" separator="," close=")">
#{item}
</foreach>
@ -24,7 +24,7 @@
select IFNULL(sum(IFNULL(x_pay,0)+IFNULL(d_pay,0)+IFNULL(y_pay,0)+IFNULL(h_pay,0)),0)
from logpm_warehouse_waybill
where 1=1
and departure_warehouse_id in
and destination_warehouse_id in
<foreach collection="param.warehouseIds" item="item" open="(" separator="," close=")">
#{item}
</foreach>
@ -45,7 +45,7 @@
<if test="param.endDate != null">
and create_time &lt;= #{param.endDate}
</if>
and departure_warehouse_id in
and destination_warehouse_id in
<foreach collection="param.warehouseIds" item="item" open="(" separator="," close=")">
#{item}
</foreach>
@ -840,7 +840,7 @@
</select>
<select id="findTotalNumByWarWarehouseId"
resultType="com.logpm.report.vo.indexCount.IndexOpenItemDataByWarWarehouseIdVO">
select departure_warehouse_id as warehouseId,departure_warehouse_name as warehouseName ,
select destination_warehouse_id as warehouseId,destination_warehouse_name as warehouseName ,
IFNULL(count(id),0) totalNum,
IFNULL(sum(total_count),0) totalCount
from logpm_warehouse_waybill
@ -851,11 +851,12 @@
<if test="param.endDate != null">
and create_time &lt;= #{param.endDate}
</if>
and departure_warehouse_id in
and destination_warehouse_id in
<foreach collection="param.warehouseIds" item="item" open="(" separator="," close=")">
#{item}
</foreach>
GROUP BY departure_warehouse_id
AND YEAR(create_time) = YEAR(CURDATE())
GROUP BY destination_warehouse_id
</select>
<select id="handOrderDataByWarehouseId" resultType="com.logpm.report.vo.IndexHandOrderDataByWarehouseIdVO">
select

5
blade-service/logpm-statisticsdata/pom.xml

@ -25,10 +25,7 @@
<groupId>org.springblade</groupId>
<artifactId>blade-starter-swagger</artifactId>
</dependency>
<dependency>
<groupId>org.springblade</groupId>
<artifactId>blade-starter-excel</artifactId>
</dependency>
<dependency>
<groupId>org.springblade</groupId>
<artifactId>blade-core-auto</artifactId>

97
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseDispatchWarehouseMonthController.java

@ -16,39 +16,20 @@
*/
package com.logpm.statistics.controller;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import com.logpm.statistics.entity.ExpenseDispatchWarehouseMonthEntity;
import com.logpm.statistics.excel.ExpenseDispatchWarehouseMonthExcel;
import com.logpm.statistics.service.IExpenseDispatchWarehouseMonthService;
import com.logpm.statistics.vo.ExpenseDispatchWarehouseMonthVO;
import com.logpm.statistics.wrapper.ExpenseDispatchWarehouseMonthWrapper;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import lombok.AllArgsConstructor;
import org.springblade.core.boot.ctrl.BladeController;
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.BladeUser;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.constant.BladeConstant;
import org.springblade.core.tool.utils.DateUtil;
import org.springblade.core.tool.utils.Func;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import springfox.documentation.annotations.ApiIgnore;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import java.util.List;
import java.util.Map;
/**
* 配送成本-仓库月度配送成本 控制器
@ -64,27 +45,6 @@ public class ExpenseDispatchWarehouseMonthController extends BladeController {
private final IExpenseDispatchWarehouseMonthService expenseDispatchWarehouseMonthService;
/**
* 配送成本-仓库月度配送成本 详情
*/
@GetMapping("/detail")
@ApiOperationSupport(order = 1)
@ApiOperation(value = "详情", notes = "传入expenseDispatchWarehouseMonth")
public R<ExpenseDispatchWarehouseMonthVO> detail(ExpenseDispatchWarehouseMonthEntity expenseDispatchWarehouseMonth) {
ExpenseDispatchWarehouseMonthEntity detail = expenseDispatchWarehouseMonthService.getOne(Condition.getQueryWrapper(expenseDispatchWarehouseMonth));
return R.data(ExpenseDispatchWarehouseMonthWrapper.build().entityVO(detail));
}
/**
* 配送成本-仓库月度配送成本 分页
*/
@GetMapping("/list")
@ApiOperationSupport(order = 2)
@ApiOperation(value = "分页", notes = "传入expenseDispatchWarehouseMonth")
public R<IPage<ExpenseDispatchWarehouseMonthVO>> list(@ApiIgnore @RequestParam Map<String, Object> expenseDispatchWarehouseMonth, Query query) {
IPage<ExpenseDispatchWarehouseMonthEntity> pages = expenseDispatchWarehouseMonthService.page(Condition.getPage(query), Condition.getQueryWrapper(expenseDispatchWarehouseMonth, ExpenseDispatchWarehouseMonthEntity.class));
return R.data(ExpenseDispatchWarehouseMonthWrapper.build().pageVO(pages));
}
/**
* 配送成本-仓库月度配送成本 自定义分页
*/
@ -96,61 +56,4 @@ public class ExpenseDispatchWarehouseMonthController extends BladeController {
return R.data(pages);
}
/**
* 配送成本-仓库月度配送成本 新增
*/
@PostMapping("/save")
@ApiOperationSupport(order = 4)
@ApiOperation(value = "新增", notes = "传入expenseDispatchWarehouseMonth")
public R save(@Valid @RequestBody ExpenseDispatchWarehouseMonthEntity expenseDispatchWarehouseMonth) {
return R.status(expenseDispatchWarehouseMonthService.save(expenseDispatchWarehouseMonth));
}
/**
* 配送成本-仓库月度配送成本 修改
*/
@PostMapping("/update")
@ApiOperationSupport(order = 5)
@ApiOperation(value = "修改", notes = "传入expenseDispatchWarehouseMonth")
public R update(@Valid @RequestBody ExpenseDispatchWarehouseMonthEntity expenseDispatchWarehouseMonth) {
return R.status(expenseDispatchWarehouseMonthService.updateById(expenseDispatchWarehouseMonth));
}
/**
* 配送成本-仓库月度配送成本 新增或修改
*/
@PostMapping("/submit")
@ApiOperationSupport(order = 6)
@ApiOperation(value = "新增或修改", notes = "传入expenseDispatchWarehouseMonth")
public R submit(@Valid @RequestBody ExpenseDispatchWarehouseMonthEntity expenseDispatchWarehouseMonth) {
return R.status(expenseDispatchWarehouseMonthService.saveOrUpdate(expenseDispatchWarehouseMonth));
}
/**
* 配送成本-仓库月度配送成本 删除
*/
@PostMapping("/remove")
@ApiOperationSupport(order = 7)
@ApiOperation(value = "逻辑删除", notes = "传入ids")
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
return R.status(expenseDispatchWarehouseMonthService.deleteLogic(Func.toLongList(ids)));
}
/**
* 导出数据
*/
@GetMapping("/export-expenseDispatchWarehouseMonth")
@ApiOperationSupport(order = 9)
@ApiOperation(value = "导出数据", notes = "传入expenseDispatchWarehouseMonth")
public void exportExpenseDispatchWarehouseMonth(@ApiIgnore @RequestParam Map<String, Object> expenseDispatchWarehouseMonth, BladeUser bladeUser, HttpServletResponse response) {
QueryWrapper<ExpenseDispatchWarehouseMonthEntity> queryWrapper = Condition.getQueryWrapper(expenseDispatchWarehouseMonth, ExpenseDispatchWarehouseMonthEntity.class);
//if (!AuthUtil.isAdministrator()) {
// queryWrapper.lambda().eq(ExpenseDispatchWarehouseMonth::getTenantId, bladeUser.getTenantId());
//}
queryWrapper.lambda().eq(ExpenseDispatchWarehouseMonthEntity::getIsDeleted, BladeConstant.DB_NOT_DELETED);
List<ExpenseDispatchWarehouseMonthExcel> list = expenseDispatchWarehouseMonthService.exportExpenseDispatchWarehouseMonth(queryWrapper);
ExcelUtil.export(response, "配送成本-仓库月度配送成本数据" + DateUtil.time(), "配送成本-仓库月度配送成本数据表", list, ExpenseDispatchWarehouseMonthExcel.class);
}
}

157
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseOrderWarehouseMonthController.java

@ -1,157 +0,0 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.statistics.controller;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import com.logpm.statistics.entity.ExpenseOrderWarehouseMonthEntity;
import com.logpm.statistics.excel.ExpenseOrderWarehouseMonthExcel;
import com.logpm.statistics.service.IExpenseOrderWarehouseMonthService;
import com.logpm.statistics.vo.ExpenseOrderWarehouseMonthVO;
import com.logpm.statistics.wrapper.ExpenseOrderWarehouseMonthWrapper;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import lombok.AllArgsConstructor;
import org.springblade.core.boot.ctrl.BladeController;
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.BladeUser;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.constant.BladeConstant;
import org.springblade.core.tool.utils.DateUtil;
import org.springblade.core.tool.utils.Func;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import springfox.documentation.annotations.ApiIgnore;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import java.util.List;
import java.util.Map;
/**
* 月度订单仓储成本明细 控制器
*
* @author BladeX
* @since 2024-07-16
*/
@RestController
@AllArgsConstructor
@RequestMapping("/expenseOrderWarehouseMonth")
@Api(value = "月度订单仓储成本明细", tags = "月度订单仓储成本明细接口")
public class ExpenseOrderWarehouseMonthController extends BladeController {
private final IExpenseOrderWarehouseMonthService expenseOrderWarehouseMonthService;
/**
* 月度订单仓储成本明细 详情
*/
@GetMapping("/detail")
@ApiOperationSupport(order = 1)
@ApiOperation(value = "详情", notes = "传入expenseOrderWarehouseMonth")
public R<ExpenseOrderWarehouseMonthVO> detail(ExpenseOrderWarehouseMonthEntity expenseOrderWarehouseMonth) {
ExpenseOrderWarehouseMonthEntity detail = expenseOrderWarehouseMonthService.getOne(Condition.getQueryWrapper(expenseOrderWarehouseMonth));
return R.data(ExpenseOrderWarehouseMonthWrapper.build().entityVO(detail));
}
/**
* 月度订单仓储成本明细 分页
*/
@GetMapping("/list")
@ApiOperationSupport(order = 2)
@ApiOperation(value = "分页", notes = "传入expenseOrderWarehouseMonth")
public R<IPage<ExpenseOrderWarehouseMonthVO>> list(@ApiIgnore @RequestParam Map<String, Object> expenseOrderWarehouseMonth, Query query) {
IPage<ExpenseOrderWarehouseMonthEntity> pages = expenseOrderWarehouseMonthService.page(Condition.getPage(query), Condition.getQueryWrapper(expenseOrderWarehouseMonth, ExpenseOrderWarehouseMonthEntity.class));
return R.data(ExpenseOrderWarehouseMonthWrapper.build().pageVO(pages));
}
/**
* 月度订单仓储成本明细 自定义分页
*/
@GetMapping("/page")
@ApiOperationSupport(order = 3)
@ApiOperation(value = "分页", notes = "传入expenseOrderWarehouseMonth")
public R<IPage<ExpenseOrderWarehouseMonthVO>> page(ExpenseOrderWarehouseMonthVO expenseOrderWarehouseMonth, Query query) {
IPage<ExpenseOrderWarehouseMonthVO> pages = expenseOrderWarehouseMonthService.selectExpenseOrderWarehouseMonthPage(Condition.getPage(query), expenseOrderWarehouseMonth);
return R.data(pages);
}
/**
* 月度订单仓储成本明细 新增
*/
@PostMapping("/save")
@ApiOperationSupport(order = 4)
@ApiOperation(value = "新增", notes = "传入expenseOrderWarehouseMonth")
public R save(@Valid @RequestBody ExpenseOrderWarehouseMonthEntity expenseOrderWarehouseMonth) {
return R.status(expenseOrderWarehouseMonthService.save(expenseOrderWarehouseMonth));
}
/**
* 月度订单仓储成本明细 修改
*/
@PostMapping("/update")
@ApiOperationSupport(order = 5)
@ApiOperation(value = "修改", notes = "传入expenseOrderWarehouseMonth")
public R update(@Valid @RequestBody ExpenseOrderWarehouseMonthEntity expenseOrderWarehouseMonth) {
return R.status(expenseOrderWarehouseMonthService.updateById(expenseOrderWarehouseMonth));
}
/**
* 月度订单仓储成本明细 新增或修改
*/
@PostMapping("/submit")
@ApiOperationSupport(order = 6)
@ApiOperation(value = "新增或修改", notes = "传入expenseOrderWarehouseMonth")
public R submit(@Valid @RequestBody ExpenseOrderWarehouseMonthEntity expenseOrderWarehouseMonth) {
return R.status(expenseOrderWarehouseMonthService.saveOrUpdate(expenseOrderWarehouseMonth));
}
/**
* 月度订单仓储成本明细 删除
*/
@PostMapping("/remove")
@ApiOperationSupport(order = 7)
@ApiOperation(value = "逻辑删除", notes = "传入ids")
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
return R.status(expenseOrderWarehouseMonthService.deleteLogic(Func.toLongList(ids)));
}
/**
* 导出数据
*/
@GetMapping("/export-expenseOrderWarehouseMonth")
@ApiOperationSupport(order = 9)
@ApiOperation(value = "导出数据", notes = "传入expenseOrderWarehouseMonth")
public void exportExpenseOrderWarehouseMonth(@ApiIgnore @RequestParam Map<String, Object> expenseOrderWarehouseMonth, BladeUser bladeUser, HttpServletResponse response) {
QueryWrapper<ExpenseOrderWarehouseMonthEntity> queryWrapper = Condition.getQueryWrapper(expenseOrderWarehouseMonth, ExpenseOrderWarehouseMonthEntity.class);
//if (!AuthUtil.isAdministrator()) {
// queryWrapper.lambda().eq(ExpenseOrderWarehouseMonth::getTenantId, bladeUser.getTenantId());
//}
queryWrapper.lambda().eq(ExpenseOrderWarehouseMonthEntity::getIsDeleted, BladeConstant.DB_NOT_DELETED);
List<ExpenseOrderWarehouseMonthExcel> list = expenseOrderWarehouseMonthService.exportExpenseOrderWarehouseMonth(queryWrapper);
ExcelUtil.export(response, "月度订单仓储成本明细数据" + DateUtil.time(), "月度订单仓储成本明细数据表", list, ExpenseOrderWarehouseMonthExcel.class);
}
}

156
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseOrderWarehouseTotalController.java

@ -1,156 +0,0 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.statistics.controller;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import com.logpm.statistics.entity.ExpenseOrderWarehouseTotalEntity;
import com.logpm.statistics.excel.ExpenseOrderWarehouseTotalExcel;
import com.logpm.statistics.service.IExpenseOrderWarehouseTotalService;
import com.logpm.statistics.vo.ExpenseOrderWarehouseTotalVO;
import com.logpm.statistics.wrapper.ExpenseOrderWarehouseTotalWrapper;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import lombok.AllArgsConstructor;
import org.springblade.core.boot.ctrl.BladeController;
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.BladeUser;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.constant.BladeConstant;
import org.springblade.core.tool.utils.DateUtil;
import org.springblade.core.tool.utils.Func;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import springfox.documentation.annotations.ApiIgnore;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import java.util.List;
import java.util.Map;
/**
* 订单总仓储成本明细 控制器
*
* @author BladeX
* @since 2024-07-16
*/
@RestController
@AllArgsConstructor
@RequestMapping("/expenseOrderWarehouseTotal")
@Api(value = "订单总仓储成本明细", tags = "订单总仓储成本明细接口")
public class ExpenseOrderWarehouseTotalController extends BladeController {
private final IExpenseOrderWarehouseTotalService expenseOrderWarehouseTotalService;
/**
* 订单总仓储成本明细 详情
*/
@GetMapping("/detail")
@ApiOperationSupport(order = 1)
@ApiOperation(value = "详情", notes = "传入expenseOrderWarehouseTotal")
public R<ExpenseOrderWarehouseTotalVO> detail(ExpenseOrderWarehouseTotalEntity expenseOrderWarehouseTotal) {
ExpenseOrderWarehouseTotalEntity detail = expenseOrderWarehouseTotalService.getOne(Condition.getQueryWrapper(expenseOrderWarehouseTotal));
return R.data(ExpenseOrderWarehouseTotalWrapper.build().entityVO(detail));
}
/**
* 订单总仓储成本明细 分页
*/
@GetMapping("/list")
@ApiOperationSupport(order = 2)
@ApiOperation(value = "分页", notes = "传入expenseOrderWarehouseTotal")
public R<IPage<ExpenseOrderWarehouseTotalVO>> list(@ApiIgnore @RequestParam Map<String, Object> expenseOrderWarehouseTotal, Query query) {
IPage<ExpenseOrderWarehouseTotalEntity> pages = expenseOrderWarehouseTotalService.page(Condition.getPage(query), Condition.getQueryWrapper(expenseOrderWarehouseTotal, ExpenseOrderWarehouseTotalEntity.class));
return R.data(ExpenseOrderWarehouseTotalWrapper.build().pageVO(pages));
}
/**
* 订单总仓储成本明细 自定义分页
*/
@GetMapping("/page")
@ApiOperationSupport(order = 3)
@ApiOperation(value = "分页", notes = "传入expenseOrderWarehouseTotal")
public R<IPage<ExpenseOrderWarehouseTotalVO>> page(ExpenseOrderWarehouseTotalVO expenseOrderWarehouseTotal, Query query) {
IPage<ExpenseOrderWarehouseTotalVO> pages = expenseOrderWarehouseTotalService.selectExpenseOrderWarehouseTotalPage(Condition.getPage(query), expenseOrderWarehouseTotal);
return R.data(pages);
}
/**
* 订单总仓储成本明细 新增
*/
@PostMapping("/save")
@ApiOperationSupport(order = 4)
@ApiOperation(value = "新增", notes = "传入expenseOrderWarehouseTotal")
public R save(@Valid @RequestBody ExpenseOrderWarehouseTotalEntity expenseOrderWarehouseTotal) {
return R.status(expenseOrderWarehouseTotalService.save(expenseOrderWarehouseTotal));
}
/**
* 订单总仓储成本明细 修改
*/
@PostMapping("/update")
@ApiOperationSupport(order = 5)
@ApiOperation(value = "修改", notes = "传入expenseOrderWarehouseTotal")
public R update(@Valid @RequestBody ExpenseOrderWarehouseTotalEntity expenseOrderWarehouseTotal) {
return R.status(expenseOrderWarehouseTotalService.updateById(expenseOrderWarehouseTotal));
}
/**
* 订单总仓储成本明细 新增或修改
*/
@PostMapping("/submit")
@ApiOperationSupport(order = 6)
@ApiOperation(value = "新增或修改", notes = "传入expenseOrderWarehouseTotal")
public R submit(@Valid @RequestBody ExpenseOrderWarehouseTotalEntity expenseOrderWarehouseTotal) {
return R.status(expenseOrderWarehouseTotalService.saveOrUpdate(expenseOrderWarehouseTotal));
}
/**
* 订单总仓储成本明细 删除
*/
@PostMapping("/remove")
@ApiOperationSupport(order = 7)
@ApiOperation(value = "逻辑删除", notes = "传入ids")
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
return R.status(expenseOrderWarehouseTotalService.deleteLogic(Func.toLongList(ids)));
}
/**
* 导出数据
*/
@GetMapping("/export-expenseOrderWarehouseTotal")
@ApiOperationSupport(order = 9)
@ApiOperation(value = "导出数据", notes = "传入expenseOrderWarehouseTotal")
public void exportExpenseOrderWarehouseTotal(@ApiIgnore @RequestParam Map<String, Object> expenseOrderWarehouseTotal, BladeUser bladeUser, HttpServletResponse response) {
QueryWrapper<ExpenseOrderWarehouseTotalEntity> queryWrapper = Condition.getQueryWrapper(expenseOrderWarehouseTotal, ExpenseOrderWarehouseTotalEntity.class);
//if (!AuthUtil.isAdministrator()) {
// queryWrapper.lambda().eq(ExpenseOrderWarehouseTotal::getTenantId, bladeUser.getTenantId());
//}
queryWrapper.lambda().eq(ExpenseOrderWarehouseTotalEntity::getIsDeleted, BladeConstant.DB_NOT_DELETED);
List<ExpenseOrderWarehouseTotalExcel> list = expenseOrderWarehouseTotalService.exportExpenseOrderWarehouseTotal(queryWrapper);
ExcelUtil.export(response, "订单总仓储成本明细数据" + DateUtil.time(), "订单总仓储成本明细数据表", list, ExpenseOrderWarehouseTotalExcel.class);
}
}

125
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseWarehouseController.java

@ -0,0 +1,125 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.statistics.controller;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import com.logpm.statistics.query.ExpenseWarehouseDayQuery;
import com.logpm.statistics.query.ExpenseWarehouseMonthQuery;
import com.logpm.statistics.query.ExpenseWarehouseOrderQuery;
import com.logpm.statistics.query.ExpenseWarehouseTransitMonthQuery;
import com.logpm.statistics.service.IExpenseOrderWarehouseTotalService;
import com.logpm.statistics.service.IExpenseWarehouseDayService;
import com.logpm.statistics.service.IExpenseWarehouseMonthService;
import com.logpm.statistics.service.IExpenseWarehousePackageDayService;
import com.logpm.statistics.vo.ExpenseWarehouseDayVO;
import com.logpm.statistics.vo.ExpenseWarehouseMonthVO;
import com.logpm.statistics.vo.ExpenseWarehouseOrderVO;
import com.logpm.statistics.vo.ExpenseWarehouseTransitMonthVO;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.AllArgsConstructor;
import org.springblade.core.boot.ctrl.BladeController;
import org.springblade.core.tool.api.R;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletResponse;
/**
* 仓储成本报表 控制器
*
* @author zqb
* @since 2024-09-23
*/
@RestController
@AllArgsConstructor
@RequestMapping("/expenseWarehouse")
@Api(value = "仓储成本报表", tags = "仓储成本报表")
public class ExpenseWarehouseController extends BladeController {
private final IExpenseWarehouseDayService expenseWarehouseDayService;
private final IExpenseWarehouseMonthService expenseWarehouseMonthService;
private final IExpenseOrderWarehouseTotalService expenseOrderWarehouseTotalService;
private final IExpenseWarehousePackageDayService packageDayService;
/**
* 日仓储成本统计表 自定义分页
*/
@GetMapping("/day")
@ApiOperationSupport(order = 1)
@ApiOperation(value = "日仓储成本统计表", notes = "日仓储成本统计表")
public R<IPage<ExpenseWarehouseDayVO>> day(ExpenseWarehouseDayQuery query) {
IPage<ExpenseWarehouseDayVO> pages = expenseWarehouseDayService.dayPage(query);
return R.data(pages);
}
@GetMapping("/exporDay")
@ApiOperation(value = "导出日仓储成本统计表", notes = "导出日仓储成本统计表")
public void exporDay(HttpServletResponse response, ExpenseWarehouseDayQuery query) {
expenseWarehouseDayService.exporDay(response, query);
}
/**
* 月度仓储成本统计表 自定义分页
*/
@GetMapping("/month")
@ApiOperationSupport(order = 2)
@ApiOperation(value = "月度仓储成本统计表", notes = "月度仓储成本统计表")
public R<IPage<ExpenseWarehouseMonthVO>> month(ExpenseWarehouseMonthQuery query) {
IPage<ExpenseWarehouseMonthVO> pages = expenseWarehouseMonthService.monthPage(query);
return R.data(pages);
}
@GetMapping("/exporMonth")
@ApiOperation(value = "导出月度仓储成本统计表", notes = "导出月度仓储成本统计表")
public void exporMonth(HttpServletResponse response, ExpenseWarehouseMonthQuery query) {
expenseWarehouseMonthService.exporMonth(response, query);
}
/**
* 订单仓储成本报表 自定义分页
*/
@GetMapping("/order")
@ApiOperationSupport(order = 3)
@ApiOperation(value = "订单仓储成本报表", notes = "订单仓储成本报表")
public R<IPage<ExpenseWarehouseOrderVO>> order(ExpenseWarehouseOrderQuery query) {
IPage<ExpenseWarehouseOrderVO> pages = expenseOrderWarehouseTotalService.orderPage(query);
return R.data(pages);
}
@GetMapping("/exporOrder")
@ApiOperation(value = "导出订单仓储成本报表", notes = "导出订单仓储成本报表")
public void exporOrder(HttpServletResponse response, ExpenseWarehouseOrderQuery query) {
expenseOrderWarehouseTotalService.exporOrder(response, query);
}
/**
* 中转仓月度收入报表 自定义分页
*/
@GetMapping("/transit")
@ApiOperationSupport(order = 4)
@ApiOperation(value = "中转仓月度收入报表", notes = "中转仓月度收入报表")
public R<IPage<ExpenseWarehouseTransitMonthVO>> transit(ExpenseWarehouseTransitMonthQuery query) {
IPage<ExpenseWarehouseTransitMonthVO> pages = packageDayService.transitPage(query);
return R.data(pages);
}
}

78
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseWarehouseDayController.java

@ -1,78 +0,0 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.statistics.controller;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import com.logpm.statistics.entity.ExpenseWarehouseDayEntity;
import com.logpm.statistics.excel.ExpenseWarehouseDayExcel;
import com.logpm.statistics.service.IExpenseWarehouseDayService;
import com.logpm.statistics.vo.ExpenseWarehouseDayVO;
import com.logpm.statistics.wrapper.ExpenseWarehouseDayWrapper;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import lombok.AllArgsConstructor;
import org.springblade.core.boot.ctrl.BladeController;
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.BladeUser;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.constant.BladeConstant;
import org.springblade.core.tool.utils.DateUtil;
import org.springblade.core.tool.utils.Func;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import springfox.documentation.annotations.ApiIgnore;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import java.util.List;
import java.util.Map;
/**
* 日仓储成本统计表 控制器
*
* @author zqb
* @since 2024-09-23
*/
@RestController
@AllArgsConstructor
@RequestMapping("/expenseWarehouseDay")
@Api(value = "日仓储成本统计表", tags = "日仓储成本统计表接口")
public class ExpenseWarehouseDayController extends BladeController {
private final IExpenseWarehouseDayService expenseWarehouseDayService;
/**
* 日仓储成本统计表 自定义分页
*/
@GetMapping("/page")
@ApiOperationSupport(order = 3)
@ApiOperation(value = "分页", notes = "传入expenseWarehouseDay")
public R<IPage<ExpenseWarehouseDayVO>> page(ExpenseWarehouseDayVO expenseWarehouseDay, Query query) {
IPage<ExpenseWarehouseDayVO> pages = expenseWarehouseDayService.selectExpenseWarehouseDayPage(Condition.getPage(query), expenseWarehouseDay);
return R.data(pages);
}
}

156
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/ExpenseWarehouseMonthController.java

@ -1,156 +0,0 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.statistics.controller;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import com.logpm.statistics.entity.ExpenseWarehouseMonthEntity;
import com.logpm.statistics.excel.ExpenseWarehouseMonthExcel;
import com.logpm.statistics.service.IExpenseWarehouseMonthService;
import com.logpm.statistics.vo.ExpenseWarehouseMonthVO;
import com.logpm.statistics.wrapper.ExpenseWarehouseMonthWrapper;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import lombok.AllArgsConstructor;
import org.springblade.core.boot.ctrl.BladeController;
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.BladeUser;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.constant.BladeConstant;
import org.springblade.core.tool.utils.DateUtil;
import org.springblade.core.tool.utils.Func;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import springfox.documentation.annotations.ApiIgnore;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import java.util.List;
import java.util.Map;
/**
* 月度仓储成本统计表 控制器
*
* @author zqb
* @since 2024-07-17
*/
@RestController
@AllArgsConstructor
@RequestMapping("/expenseWarehouseMonth")
@Api(value = "月度仓储成本统计表", tags = "月度仓储成本统计表接口")
public class ExpenseWarehouseMonthController extends BladeController {
private final IExpenseWarehouseMonthService expenseWarehouseMonthService;
/**
* 月度仓储成本统计表 详情
*/
@GetMapping("/detail")
@ApiOperationSupport(order = 1)
@ApiOperation(value = "详情", notes = "传入expenseWarehouseMonth")
public R<ExpenseWarehouseMonthVO> detail(ExpenseWarehouseMonthEntity expenseWarehouseMonth) {
ExpenseWarehouseMonthEntity detail = expenseWarehouseMonthService.getOne(Condition.getQueryWrapper(expenseWarehouseMonth));
return R.data(ExpenseWarehouseMonthWrapper.build().entityVO(detail));
}
/**
* 月度仓储成本统计表 分页
*/
@GetMapping("/list")
@ApiOperationSupport(order = 2)
@ApiOperation(value = "分页", notes = "传入expenseWarehouseMonth")
public R<IPage<ExpenseWarehouseMonthVO>> list(@ApiIgnore @RequestParam Map<String, Object> expenseWarehouseMonth, Query query) {
IPage<ExpenseWarehouseMonthEntity> pages = expenseWarehouseMonthService.page(Condition.getPage(query), Condition.getQueryWrapper(expenseWarehouseMonth, ExpenseWarehouseMonthEntity.class));
return R.data(ExpenseWarehouseMonthWrapper.build().pageVO(pages));
}
/**
* 月度仓储成本统计表 自定义分页
*/
@GetMapping("/page")
@ApiOperationSupport(order = 3)
@ApiOperation(value = "分页", notes = "传入expenseWarehouseMonth")
public R<IPage<ExpenseWarehouseMonthVO>> page(ExpenseWarehouseMonthVO expenseWarehouseMonth, Query query) {
IPage<ExpenseWarehouseMonthVO> pages = expenseWarehouseMonthService.selectExpenseWarehouseMonthPage(Condition.getPage(query), expenseWarehouseMonth);
return R.data(pages);
}
/**
* 月度仓储成本统计表 新增
*/
@PostMapping("/save")
@ApiOperationSupport(order = 4)
@ApiOperation(value = "新增", notes = "传入expenseWarehouseMonth")
public R save(@Valid @RequestBody ExpenseWarehouseMonthEntity expenseWarehouseMonth) {
return R.status(expenseWarehouseMonthService.save(expenseWarehouseMonth));
}
/**
* 月度仓储成本统计表 修改
*/
@PostMapping("/update")
@ApiOperationSupport(order = 5)
@ApiOperation(value = "修改", notes = "传入expenseWarehouseMonth")
public R update(@Valid @RequestBody ExpenseWarehouseMonthEntity expenseWarehouseMonth) {
return R.status(expenseWarehouseMonthService.updateById(expenseWarehouseMonth));
}
/**
* 月度仓储成本统计表 新增或修改
*/
@PostMapping("/submit")
@ApiOperationSupport(order = 6)
@ApiOperation(value = "新增或修改", notes = "传入expenseWarehouseMonth")
public R submit(@Valid @RequestBody ExpenseWarehouseMonthEntity expenseWarehouseMonth) {
return R.status(expenseWarehouseMonthService.saveOrUpdate(expenseWarehouseMonth));
}
/**
* 月度仓储成本统计表 删除
*/
@PostMapping("/remove")
@ApiOperationSupport(order = 7)
@ApiOperation(value = "逻辑删除", notes = "传入ids")
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
return R.status(expenseWarehouseMonthService.deleteLogic(Func.toLongList(ids)));
}
/**
* 导出数据
*/
@GetMapping("/export-expenseWarehouseMonth")
@ApiOperationSupport(order = 9)
@ApiOperation(value = "导出数据", notes = "传入expenseWarehouseMonth")
public void exportExpenseWarehouseMonth(@ApiIgnore @RequestParam Map<String, Object> expenseWarehouseMonth, BladeUser bladeUser, HttpServletResponse response) {
QueryWrapper<ExpenseWarehouseMonthEntity> queryWrapper = Condition.getQueryWrapper(expenseWarehouseMonth, ExpenseWarehouseMonthEntity.class);
//if (!AuthUtil.isAdministrator()) {
// queryWrapper.lambda().eq(ExpenseWarehouseMonth::getTenantId, bladeUser.getTenantId());
//}
queryWrapper.lambda().eq(ExpenseWarehouseMonthEntity::getIsDeleted, BladeConstant.DB_NOT_DELETED);
List<ExpenseWarehouseMonthExcel> list = expenseWarehouseMonthService.exportExpenseWarehouseMonth(queryWrapper);
ExcelUtil.export(response, "月度仓储成本统计表数据" + DateUtil.time(), "月度仓储成本统计表数据表", list, ExpenseWarehouseMonthExcel.class);
}
}

72
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/controller/MerchantStatisticsController.java

@ -100,6 +100,55 @@ public class MerchantStatisticsController {
}
}
@ResponseBody
@PostMapping("/createFinishWaybillId")
@ApiOperationSupport(order = 1)
@ApiOperation(value = "批量结算完成", notes = "传入merchantStatisticsDTO")
public R createFinishWaybillId(@RequestBody MerchantStatisticsDTO merchantStatisticsDTO) {
String method = "############createReconciliationOrder: ";
log.info(method + "请求参数{}", merchantStatisticsDTO);
try {
List<Long> waybillIds = merchantStatisticsDTO.getWaybillIds();
if (CollUtil.isEmpty(waybillIds)) {
log.warn(method + "请选择正确的订单 merchantStatisticsDTO={}", merchantStatisticsDTO);
return R.fail(405, "请选择正确的订单");
}
return statisticsOrderInfoService.createFinishWaybillId(waybillIds);
} catch (CustomerException e) {
log.error(e.message, e);
return R.fail(e.code, e.message);
} catch (Exception e) {
log.error(method + "系统异常", e);
return R.fail(500, "系统异常");
}
}
@ResponseBody
@PostMapping("/createReconciliationwWaybillId")
@ApiOperationSupport(order = 1)
@ApiOperation(value = "创建对账单", notes = "传入merchantStatisticsDTO")
public R createReconciliationwWaybillId(@RequestBody MerchantStatisticsDTO merchantStatisticsDTO) {
String method = "############createReconciliationOrder: ";
log.info(method + "请求参数{}", merchantStatisticsDTO);
try {
List<Long> waybillIds = merchantStatisticsDTO.getWaybillIds();
if (CollUtil.isEmpty(waybillIds)) {
log.warn(method + "请选择正确的订单 merchantStatisticsDTO={}", merchantStatisticsDTO);
return R.fail(405, "请选择正确的订单");
}
return statisticsOrderInfoService.createReconciliationWaybillId(waybillIds);
} catch (CustomerException e) {
log.error(e.message, e);
return R.fail(e.code, e.message);
} catch (Exception e) {
log.error(method + "系统异常", e);
return R.fail(500, "系统异常");
}
}
@ResponseBody
@PostMapping("/pageReconciliationList")
@ApiOperationSupport(order = 1)
@ -368,4 +417,27 @@ public class MerchantStatisticsController {
}
@ResponseBody
@PatchMapping("/calculateRealCostByWaybillId/{id}")
@ApiOperationSupport(order = 1)
@ApiOperation(value = "计算实际费用", notes = "计算实际费用")
public R<Boolean> calculateRealCostByWaybillId(@PathVariable("id") Long id) {
String method = "############calculateRealCost: ";
log.info(method + "请求参数{}", id);
try {
return R.status(statisticsOrderInfoService.calculateRealCostByWaybillId(id));
} catch (CustomerException e) {
log.error(e.message, e);
return R.fail(e.code, e.message);
} catch (Exception e) {
log.error(method + "系统异常", e);
return R.fail(500, "系统异常");
}
}
}

133
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/job/ExpenseJob.java

@ -17,6 +17,7 @@ import com.logpm.statistics.entity.ExpenseWarehouseDayEntity;
import com.logpm.statistics.entity.ExpenseWarehouseMonthEntity;
import com.logpm.statistics.service.IExpenseWarehouseDayService;
import com.logpm.statistics.service.IExpenseWarehouseMonthService;
import com.logpm.trunkline.feign.ITrunklineCarsLoadScanClient;
import com.xxl.job.core.biz.model.ReturnT;
import com.xxl.job.core.handler.annotation.XxlJob;
import lombok.AllArgsConstructor;
@ -53,6 +54,8 @@ public class ExpenseJob {
private IExpenseWarehouseDayService warehouseDayService;
@Resource
private IExpenseWarehouseMonthService warehouseMonthService;
@Resource
private ITrunklineCarsLoadScanClient carsLoadScanClient;
/**
* 仓库月度仓储成本统计表
@ -69,7 +72,7 @@ public class ExpenseJob {
if (StrUtil.isNotEmpty(param)) {
statisticsTime = DateUtil.parseDate(param);
}
List<ExpenseWarehouseMonthEntity> monthEntityList = warehouseDayService.statisticsMonthWarehouseExpense(DateUtil.year(statisticsTime), DateUtil.month(statisticsTime));
List<ExpenseWarehouseMonthEntity> monthEntityList = warehouseDayService.statisticsMonthWarehouseExpense(DateUtil.year(statisticsTime), DateUtil.month(statisticsTime) + 1);
if (CollUtil.isNotEmpty(monthEntityList)) {
warehouseMonthService.saveBatch(monthEntityList);
}
@ -94,7 +97,7 @@ public class ExpenseJob {
// 当前时间对应月分的总天数
Integer dayOfMonth = getDaysByDate(statisticsTime);
// 统计当天系统中所有仓库的成本
List<BasicdataWarehouseEntity> warehouses = warehouseClient.findAllList();
List<BasicdataWarehouseEntity> warehouses = warehouseClient.findAllListBusinessLine();
if (CollUtil.isNotEmpty(warehouses)) {
// 通过仓库id查询客户租金
List<WarehouseLeasingEntity> warehouseLeasingEntities = warehouseLeasingClient.findListByWarehouseIds(warehouses.stream().map(BasicdataWarehouseEntity::getId).collect(Collectors.toList()), DateUtil.formatDate(statisticsTime));
@ -103,7 +106,7 @@ public class ExpenseJob {
if (CollUtil.isNotEmpty(warehouseLeasingEntities)) {
warehouseLeasingEntities.forEach(warehouseLeasingEntity -> {
clientIdSet.add(warehouseLeasingEntity.getClientId());
if (warehouseLeasingEntityMap.containsKey(warehouseLeasingEntity.getWarehouseId())) {
if (!warehouseLeasingEntityMap.containsKey(warehouseLeasingEntity.getWarehouseId())) {
WarehouseLeasingEntity leasingEntity = new WarehouseLeasingEntity();
leasingEntity.setLeasedArea(warehouseLeasingEntity.getLeasedArea());
leasingEntity.setMonthlyRent(warehouseLeasingEntity.getMonthlyRent());
@ -124,6 +127,9 @@ public class ExpenseJob {
// 统计配送出库件数
List<QualityDeliverEntity> qualityDeliverEntities = qualityDeliverClient.findSignListByDate(DateUtil.formatDate(statisticsTime));
Map<Long, ExpenseWarehouseDayEntity> qualityDeliverEntityMap = new HashMap<>();
Map<Long, List<QualityDeliverEntity>> customMap = new HashMap<>();
Map<Long, List<QualityDeliverEntity>> tempMap = new HashMap<>();
Map<Long, List<QualityDeliverEntity>> gcpMap = new HashMap<>();
if (CollUtil.isNotEmpty(qualityDeliverEntities)) {
// 每个仓有多少数据
Map<Long, List<QualityDeliverEntity>> map = qualityDeliverEntities.stream().collect(Collectors.groupingBy(QualityDeliverEntity::getWarehouseId));
@ -131,12 +137,15 @@ public class ExpenseJob {
ExpenseWarehouseDayEntity entity = new ExpenseWarehouseDayEntity();
// 单仓的包件明细
List<QualityDeliverEntity> value = longListEntry.getValue();
QualityDeliverEntity entity1 = value.get(0);
entity.setBusinessUnit(entity1.getBusinessUnit());
// 统计该仓所有归属租用客户的包件
List<QualityDeliverEntity> leasingList = value.stream().filter(item -> clientIdSet.contains(item.getAssignedCustomerId())).collect(Collectors.toList());
if (CollUtil.isNotEmpty(leasingList)) {
customMap.put(longListEntry.getKey(), leasingList);
// 计算签收数量的和
BigDecimal totalSignCount = leasingList.stream().map(t -> Convert.toBigDecimal(t.getSignNum())).reduce(BigDecimal.ZERO, BigDecimal::add);
entity.setRentedItemsDispatchedQuantity(Convert.toStr(totalSignCount));
BigDecimal totalOutQuantity = leasingList.stream().map(t -> Convert.toBigDecimal(t.getSignNum())).reduce(BigDecimal.ZERO, BigDecimal::add);
entity.setCustomerRentalOutQuantity(Convert.toInt(totalOutQuantity));
}
List<QualityDeliverEntity> tempList = value.stream()
// 过滤掉客户租用的
@ -145,9 +154,10 @@ public class ExpenseJob {
.filter(item -> !StrUtil.equals(item.getDeliveryType(), "市配"))
.collect(Collectors.toList());
if (CollUtil.isNotEmpty(tempList)) {
tempMap.put(longListEntry.getKey(), tempList);
// 计算签收数量的和
BigDecimal totalSignCount = tempList.stream().map(t -> Convert.toBigDecimal(t.getSignNum())).reduce(BigDecimal.ZERO, BigDecimal::add);
entity.setTemporaryTurnoverQuantity(Convert.toStr(totalSignCount));
entity.setTemporaryTurnoverQuantity(Convert.toInt(totalSignCount));
}
List<QualityDeliverEntity> gapList = value.stream()
// 过滤掉客户租用的
@ -156,16 +166,20 @@ public class ExpenseJob {
.filter(item -> StrUtil.equals(item.getDeliveryType(), "市配"))
.collect(Collectors.toList());
if (CollUtil.isNotEmpty(gapList)) {
gcpMap.put(longListEntry.getKey(), gapList);
// 计算签收数量的和
BigDecimal totalSignCount = gapList.stream().map(t -> Convert.toBigDecimal(t.getSignNum())).reduce(BigDecimal.ZERO, BigDecimal::add);
entity.setDrWareDisNumber(Convert.toStr(totalSignCount));
entity.setDrWareDisNumber(Convert.toInt(totalSignCount));
}
qualityDeliverEntityMap.put(longListEntry.getKey(), entity);
}
}
List<ExpenseWarehouseDayEntity> warehouseDayEntities = new ArrayList<>();
Map<Long, BigDecimal> packageCostMap = new HashMap<>();
for (BasicdataWarehouseEntity warehouse : warehouses) {
ExpenseWarehouseDayEntity entity = new ExpenseWarehouseDayEntity();
entity.setBusinessUnit(warehouse.getBusinessLine());
entity.setDayNumber(dayOfMonth);
// 初始化仓库基础数据
initWarehouseBasicInfo(entity, warehouse, statisticsTime);
Long warehouseId = warehouse.getId();
@ -176,14 +190,14 @@ public class ExpenseJob {
// 临时周转面积
BigDecimal temporaryTurnoverArea = warehouse.getTemporaryTurnoverArea();
if (ObjectUtil.isNotEmpty(temporaryTurnoverArea)) {
entity.setTemporaryTurnoverArea(Convert.toStr(temporaryTurnoverArea));
entity.setTemporaryTurnoverArea(temporaryTurnoverArea);
}
// 临时周转日成本 = (临时周转面积/仓库总面积)*(仓库月租金/天数)
if (ObjectUtil.isNotEmpty(acreage)
&& ObjectUtil.isNotEmpty(unitPrice)
&& ObjectUtil.isNotEmpty(temporaryTurnoverArea)) {
BigDecimal temCost = NumberUtil.div(NumberUtil.mul(temporaryTurnoverArea, unitPrice), NumberUtil.mul(acreage, dayOfMonth), 6);
entity.setTotalTemporaryTurnoverCost(Convert.toStr(temCost));
BigDecimal temporaryTurnoverTotalCost = NumberUtil.div(NumberUtil.mul(temporaryTurnoverArea, unitPrice), NumberUtil.mul(acreage, dayOfMonth), 4);
entity.setTemporaryTurnoverTotalCost(temporaryTurnoverTotalCost);
}
// 客户租用总面积
BigDecimal totalLeasedArea = BigDecimal.ZERO;
@ -193,20 +207,21 @@ public class ExpenseJob {
BigDecimal leasedArea = leasingEntity.getLeasedArea();
if (ObjectUtil.isNotEmpty(totalLeasedArea)) {
totalLeasedArea = leasedArea;
entity.setCustomerLeasedArea(Convert.toStr(leasedArea));
entity.setCustomerRentalArea(leasedArea);
}
BigDecimal monthlyRent = leasingEntity.getMonthlyRent();
// 客户日租金
if (ObjectUtil.isNotEmpty(monthlyRent)) {
BigDecimal dayRent = NumberUtil.div(monthlyRent, dayOfMonth, 6);
entity.setCustomerMonthlyRent(Convert.toStr(dayRent));
BigDecimal dayRent = NumberUtil.div(monthlyRent, dayOfMonth, 4);
entity.setCustomerMonthlyRent(monthlyRent);
entity.setCustomerDailyRent(dayRent);
}
// 客户租用成本 = (客户租用面积/仓库总面积)*(仓库月租金/天数)
if (ObjectUtil.isNotEmpty(acreage)
&& ObjectUtil.isNotEmpty(unitPrice)
&& ObjectUtil.isNotEmpty(leasedArea)) {
BigDecimal temCost = NumberUtil.div(NumberUtil.mul(leasedArea, unitPrice), NumberUtil.mul(acreage, dayOfMonth), 6);
entity.setCustomerTotalLeasingCost(Convert.toStr(temCost));
BigDecimal customerTotalRentalCost = NumberUtil.div(NumberUtil.mul(leasedArea, unitPrice), NumberUtil.mul(acreage, dayOfMonth), 4);
entity.setCustomerTotalRentalCost(customerTotalRentalCost);
}
}
// 计算仓库的干仓配
@ -217,38 +232,62 @@ public class ExpenseJob {
gcpArea = NumberUtil.sub(gcpArea, temporaryTurnoverArea);
}
gcpArea = NumberUtil.sub(gcpArea, totalLeasedArea);
entity.setDrWareDisArea(Convert.toStr(gcpArea));
entity.setDrWareDisArea(gcpArea);
if (ObjectUtil.isNotEmpty(acreage)
&& ObjectUtil.isNotEmpty(unitPrice)) {
if (!NumberUtil.equals(NumberUtil.mul(acreage, dayOfMonth), BigDecimal.ZERO)) {
BigDecimal temCost = NumberUtil.div(NumberUtil.mul(gcpArea, unitPrice), NumberUtil.mul(acreage, dayOfMonth), 6);
entity.setDrWareDisTotalCost(Convert.toStr(temCost));
BigDecimal temCost = NumberUtil.div(NumberUtil.mul(gcpArea, unitPrice), NumberUtil.mul(acreage, dayOfMonth), 4);
entity.setDrWareDisTotalCost(temCost);
}
}
}
if (CollUtil.isNotEmpty(qualityDeliverEntityMap)) {
if (qualityDeliverEntityMap.containsKey(warehouseId)) {
// 租用客户件数
entity.setRentedItemsDispatchedQuantity(qualityDeliverEntityMap.get(warehouseId).getRentedItemsDispatchedQuantity());
entity.setCustomerRentalOutQuantity(qualityDeliverEntityMap.get(warehouseId).getCustomerRentalOutQuantity());
// 租用客户单件成本
if (StrUtil.isNotEmpty(entity.getRentedItemsDispatchedQuantity()) && !StrUtil.equals(entity.getRentedItemsDispatchedQuantity(), "0")) {
log.info("租用客户出库数:{}", entity.getRentedItemsDispatchedQuantity());
entity.setCustomerRentedItemCostPerUnit(Convert.toStr(NumberUtil.div(entity.getCustomerTotalLeasingCost(), entity.getRentedItemsDispatchedQuantity(), 6)));
if (ObjectUtil.isNotEmpty(entity.getCustomerRentalOutQuantity()) && !NumberUtil.equals(entity.getCustomerRentalOutQuantity(), 0)) {
BigDecimal div = NumberUtil.div(entity.getCustomerTotalRentalCost(), entity.getCustomerRentalOutQuantity(), 4);
entity.setCustomerRentalUnitCost(div);
// 计算包件单件成本
List<QualityDeliverEntity> qualityDeliverEntities1 = customMap.get(warehouseId);
if (CollUtil.isNotEmpty(qualityDeliverEntities1)) {
for (QualityDeliverEntity qualityDeliverEntity : qualityDeliverEntities1) {
packageCostMap.put(qualityDeliverEntity.getId(), NumberUtil.mul(div, qualityDeliverEntity.getSignNum()));
}
}
}
// 临时周转件数
entity.setTemporaryTurnoverQuantity(qualityDeliverEntityMap.get(warehouseId).getTemporaryTurnoverQuantity());
// 临时周转单件成本
if (StrUtil.isNotEmpty(entity.getTemporaryTurnoverQuantity()) && !StrUtil.equals(entity.getTemporaryTurnoverQuantity(), "0")) {
entity.setTemporaryTurnoverCostPerItem(Convert.toStr(NumberUtil.div(entity.getTotalTemporaryTurnoverCost(), entity.getTemporaryTurnoverQuantity(), 6)));
if (ObjectUtil.isNotEmpty(entity.getTemporaryTurnoverQuantity()) && !NumberUtil.equals(entity.getTemporaryTurnoverQuantity(), 0)) {
BigDecimal div = NumberUtil.div(entity.getTemporaryTurnoverTotalCost(), entity.getTemporaryTurnoverQuantity(), 4);
entity.setTemporaryTurnoverUnitCost(div);
// 计算包件单件成本
List<QualityDeliverEntity> qualityDeliverEntities1 = tempMap.get(warehouseId);
if (CollUtil.isNotEmpty(qualityDeliverEntities1)) {
for (QualityDeliverEntity qualityDeliverEntity : qualityDeliverEntities1) {
packageCostMap.put(qualityDeliverEntity.getId(), NumberUtil.mul(div, qualityDeliverEntity.getSignNum()));
}
}
}
// 干仓配件数
entity.setDrWareDisNumber(qualityDeliverEntityMap.get(warehouseId).getDrWareDisNumber());
// 干仓配件单件成本
if (StrUtil.isNotEmpty(entity.getDrWareDisNumber()) && !StrUtil.equals(entity.getDrWareDisNumber(), "0")) {
entity.setDrWareDisCostPerUnit(Convert.toStr(NumberUtil.div(entity.getDrWareDisTotalCost(), entity.getDrWareDisNumber(), 6)));
if (ObjectUtil.isNotEmpty(entity.getDrWareDisNumber()) && !NumberUtil.equals(entity.getDrWareDisNumber(), 0)) {
BigDecimal div = NumberUtil.div(entity.getDrWareDisTotalCost(), entity.getDrWareDisNumber(), 4);
entity.setDrWareDisCostPerUnit(div);
List<QualityDeliverEntity> qualityDeliverEntities1 = gcpMap.get(warehouseId);
if (CollUtil.isNotEmpty(qualityDeliverEntities1)) {
for (QualityDeliverEntity qualityDeliverEntity : qualityDeliverEntities1) {
packageCostMap.put(qualityDeliverEntity.getId(), NumberUtil.mul(div, qualityDeliverEntity.getSignNum()));
}
}
}
// 不为空的相加计算出总出库数
entity.setTotalQuantityIssued(Convert.toStr(NumberUtil.add(entity.getRentedItemsDispatchedQuantity(), entity.getTemporaryTurnoverQuantity(), entity.getDrWareDisNumber())));
entity.setTotalOutQuantity(Convert.toInt(NumberUtil.add(entity.getCustomerRentalOutQuantity(), entity.getTemporaryTurnoverQuantity(), entity.getDrWareDisNumber())));
// 计算总成本
entity.setWarehouseCost(NumberUtil.add(entity.getCustomerTotalRentalCost(), entity.getTemporaryTurnoverTotalCost(), entity.getDrWareDisTotalCost()));
}
}
warehouseDayEntities.add(entity);
@ -256,29 +295,53 @@ public class ExpenseJob {
if (CollUtil.isNotEmpty(warehouseDayEntities)) {
warehouseDayService.saveBatch(warehouseDayEntities);
}
if (CollUtil.isNotEmpty(packageCostMap)) {
qualityDeliverClient.updateWarehouseCost(packageCostMap);
}
}
return ReturnT.SUCCESS;
}
/**
* 包件日仓储成本统计 统计代入导出成本
* 每日凌晨3点10分计算
*
* @param param
* @return
* @throws Exception
*/
@XxlJob("dayPackageWarehouseExpenseJob")
public ReturnT<String> dayPackageWarehouseExpenseJob(String param) throws Exception {
log.info("dayPackageWarehouseExpenseJob 参数:{}", param);
DateTime statisticsTime = DateUtil.yesterday();
if (StrUtil.isNotEmpty(param)) {
statisticsTime = DateUtil.parseDate(param);
}
//
return ReturnT.SUCCESS;
}
private Integer getDaysByDate(DateTime statisticsTime) {
return YearMonth.of(DateUtil.year(statisticsTime), DateUtil.month(statisticsTime)).lengthOfMonth();
return YearMonth.of(DateUtil.year(statisticsTime), DateUtil.month(statisticsTime) + 1).lengthOfMonth();
}
private void initWarehouseBasicInfo(ExpenseWarehouseDayEntity entity, BasicdataWarehouseEntity warehouse, DateTime statisticsTime) {
entity.setCostSettlementYear(Convert.toStr(DateUtil.year(statisticsTime)));
entity.setCostSettlementMonth(Convert.toStr(DateUtil.month(statisticsTime)) + 1);
entity.setCostSettlementDay(Convert.toStr(DateUtil.dayOfMonth(statisticsTime)));
entity.setCostSettlement(DateUtil.formatDate(statisticsTime));
entity.setStatisticalYear(DateUtil.year(statisticsTime));
entity.setStatisticalMonth(DateUtil.month(statisticsTime) + 1);
entity.setStatisticalDay(DateUtil.dayOfMonth(statisticsTime));
entity.setStatisticalTime(DateUtil.formatDate(statisticsTime));
entity.setWarehouseName(warehouse.getName());
// 面积
entity.setTotalArea(Convert.toStr(warehouse.getAcreage()));
entity.setTotalArea(warehouse.getAcreage());
BigDecimal unitPrice = warehouse.getUnitPrice();
Integer daysByDate = getDaysByDate(statisticsTime);
if (ObjectUtil.isNotEmpty(unitPrice)) {
entity.setRent(unitPrice);
// 日租金
entity.setMonthlyRent(Convert.toStr(NumberUtil.div(unitPrice, daysByDate, 6)));
entity.setDailyRent(NumberUtil.div(unitPrice, daysByDate, 4));
}
entity.setTemporaryTurnoverArea(Convert.toStr(warehouse.getTemporaryTurnoverArea()));
entity.setTemporaryTurnoverArea(warehouse.getTemporaryTurnoverArea());
}
}

8
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/listener/mq/WaybillCheckListener.java

@ -85,10 +85,10 @@ public class WaybillCheckListener {
log.warn("###############checkWaybillIncomingData: 运单类型不正确 waybillId={} waybillType={}", waybillId, waybillType);
}
if (payWay.equals("1") || payWay.equals("2")) {
//如果是现付和到付需要直接生成结算单
createBalanceOrder(waybillEntity);
}
// if (payWay.equals("1") || payWay.equals("2")) {
// //如果是现付和到付需要直接生成结算单
// createBalanceOrder(waybillEntity);
// }
log.info("#########checkWaybillIncomingData: 运单审核处理收入结算数据 结束 waybillId={}", waybillId);
}

11
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseOrderWarehouseTotalMapper.java

@ -16,8 +16,9 @@
*/
package com.logpm.statistics.mapper;
import com.logpm.statistics.entity.ExpenseOrderWarehouseTotalEntity;
import com.logpm.statistics.vo.ExpenseOrderWarehouseTotalVO;
import com.logpm.statistics.entity.ExpenseWarehouseOrderEntity;
import com.logpm.statistics.query.ExpenseWarehouseOrderQuery;
import com.logpm.statistics.vo.ExpenseWarehouseOrderVO;
import com.logpm.statistics.excel.ExpenseOrderWarehouseTotalExcel;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
@ -31,7 +32,7 @@ import java.util.List;
* @author BladeX
* @since 2024-07-16
*/
public interface ExpenseOrderWarehouseTotalMapper extends BaseMapper<ExpenseOrderWarehouseTotalEntity> {
public interface ExpenseOrderWarehouseTotalMapper extends BaseMapper<ExpenseWarehouseOrderEntity> {
/**
* 自定义分页
@ -40,7 +41,7 @@ public interface ExpenseOrderWarehouseTotalMapper extends BaseMapper<ExpenseOrde
* @param expenseOrderWarehouseTotal
* @return
*/
List<ExpenseOrderWarehouseTotalVO> selectExpenseOrderWarehouseTotalPage(IPage page, ExpenseOrderWarehouseTotalVO expenseOrderWarehouseTotal);
List<ExpenseWarehouseOrderVO> selectExpenseOrderWarehouseTotalPage(@Param("page") IPage page, @Param("query") ExpenseWarehouseOrderQuery expenseOrderWarehouseTotal);
/**
@ -49,6 +50,6 @@ public interface ExpenseOrderWarehouseTotalMapper extends BaseMapper<ExpenseOrde
* @param queryWrapper
* @return
*/
List<ExpenseOrderWarehouseTotalExcel> exportExpenseOrderWarehouseTotal(@Param("ew") Wrapper<ExpenseOrderWarehouseTotalEntity> queryWrapper);
List<ExpenseOrderWarehouseTotalExcel> exportExpenseOrderWarehouseTotal(@Param("ew") Wrapper<ExpenseWarehouseOrderEntity> queryWrapper);
}

45
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseOrderWarehouseTotalMapper.xml

@ -3,12 +3,51 @@
<mapper namespace="com.logpm.statistics.mapper.ExpenseOrderWarehouseTotalMapper">
<!-- 通用查询映射结果 -->
<resultMap id="expenseOrderWarehouseTotalResultMap" type="com.logpm.statistics.entity.ExpenseOrderWarehouseTotalEntity">
<resultMap id="expenseOrderWarehouseTotalResultMap" type="com.logpm.statistics.entity.ExpenseWarehouseOrderEntity">
</resultMap>
<select id="selectExpenseOrderWarehouseTotalPage" resultMap="expenseOrderWarehouseTotalResultMap">
select * from logpm_expense_order_warehouse_total where is_deleted = 0
<select id="selectExpenseOrderWarehouseTotalPage" resultType="com.logpm.statistics.vo.ExpenseWarehouseOrderVO">
select * from (
select warehouse_name warehouseName,
order_code orderCode,
waybill_number shipmentNumber,
consignee_unit receivingUnit,
shipper_unit shippingUnit,
delivery_type deliveryType,
ifnull(order_number,0) totalNumber,
ifnull(sum(review_num),0) outNumber,
begin_warehouse_name originWarehouse,
ifnull(sum(warehouse_cost),0) warehouseRentalCost,
case when ifnull(order_number,0) = ifnull(sum(review_num),0) then '已完成' else '未完成' end reviewStatus
from logpm_quality_deliver
<where>
review_time is not null
and order_code is not null
<if test="query.orderCode != null and query.orderCode != ''">
and order_code = #{query.orderCode}
</if>
<if test="query.shipmentNumber != null and query.shipmentNumber != ''">
and waybill_number = #{query.shipmentNumber}
</if>
<if test="query.warehouseName != null and query.warehouseName != ''">
and warehouse_name in
<foreach collection="query.warehouseName.split(',')" item="item" separator="," open="(" close=")">
#{item}
</foreach>
</if>
</where>
group by order_code) t
<where>
<if test="query.reviewStatus != null and query.reviewStatus != ''">
<if test="query.reviewStatus == '已完成'">
and t.totalNumber = t.outNumber
</if>
<if test="query.reviewStatus == '未完成'">
and totalNumber != t.outNumber
</if>
</if>
</where>
</select>

3
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehouseDayMapper.java

@ -18,6 +18,7 @@ package com.logpm.statistics.mapper;
import com.logpm.statistics.entity.ExpenseWarehouseDayEntity;
import com.logpm.statistics.entity.ExpenseWarehouseMonthEntity;
import com.logpm.statistics.query.ExpenseWarehouseDayQuery;
import com.logpm.statistics.vo.ExpenseWarehouseDayVO;
import com.logpm.statistics.excel.ExpenseWarehouseDayExcel;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
@ -41,7 +42,7 @@ public interface ExpenseWarehouseDayMapper extends BaseMapper<ExpenseWarehouseDa
* @param expenseWarehouseDay
* @return
*/
List<ExpenseWarehouseDayVO> selectExpenseWarehouseDayPage(@Param("page") IPage page, @Param("expenseWarehouseDay") ExpenseWarehouseDayVO expenseWarehouseDay);
List<ExpenseWarehouseDayVO> selectExpenseWarehouseDayPage(@Param("page") IPage page, @Param("expenseWarehouseDay") ExpenseWarehouseDayQuery expenseWarehouseDay);
/**

108
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehouseDayMapper.xml

@ -7,54 +7,72 @@
</resultMap>
<select id="selectExpenseWarehouseDayPage" resultMap="expenseWarehouseDayResultMap">
select * from logpm_expense_warehouse_day
where is_deleted = 0
<if test="expenseWarehouseDay.startDateQuery != null and expenseWarehouseDay.startDateQuery != ''">
and cost_settlement >= #{expenseWarehouseDay.startDateQuery}
</if>
<if test="expenseWarehouseDay.endDateQuery != null and expenseWarehouseDay.endDateQuery != ''">
and cost_settlement <![CDATA[ <= ]]> #{expenseWarehouseDay.endDateQuery}
</if>
<if test="expenseWarehouseDay.warehouseNameQuery != null and expenseWarehouseDay.warehouseNameQuery != ''">
and warehouse_name in
<foreach collection="expenseWarehouseDay.warehouseNameQuery.split(',')" item="item" separator="," open="(" close=")">
#{item}
</foreach>
</if>
</select>
<select id="exportExpenseWarehouseDay" resultType="com.logpm.statistics.excel.ExpenseWarehouseDayExcel">
SELECT * FROM logpm_expense_warehouse_day ${ew.customSqlSegment}
<select id="selectExpenseWarehouseDayPage" resultType="com.logpm.statistics.vo.ExpenseWarehouseDayVO">
select
business_unit,
warehouse_name,
statistical_year,
statistical_month,
statistical_day,
statistical_time,
day_number,
round(ifnull(total_area,0),2) total_area,
round(ifnull(rent,0),2) rent,
round(ifnull(daily_rent,0),2) daily_rent,
round(ifnull(total_out_quantity,0),2) total_out_quantity,
round(ifnull(customer_rental_area,0),2) customer_rental_area,
round(ifnull(customer_monthly_rent,0),2) customer_monthly_rent,
round(ifnull(customer_daily_rent,0),2) customer_daily_rent,
round(ifnull(customer_rental_out_quantity,0),2) customer_rental_out_quantity,
round(ifnull(customer_rental_unit_cost,0),2) customer_rental_unit_cost,
round(ifnull(customer_total_rental_cost,0),2) customer_total_rental_cost,
round(ifnull(temporary_turnover_area,0),2) temporary_turnover_area,
round(ifnull(temporary_turnover_quantity,0),2) temporary_turnover_quantity,
round(ifnull(temporary_turnover_unit_cost,0),2) temporary_turnover_unit_cost,
round(ifnull(temporary_turnover_total_cost,0),2) temporary_turnover_total_cost,
round(ifnull(dr_ware_dis_area,0),2) dr_ware_dis_area,
round(ifnull(dr_ware_dis_number,0),2) dr_ware_dis_number,
round(ifnull(dr_ware_dis_cost_per_unit,0),2) dr_ware_dis_cost_per_unit,
round(ifnull(dr_ware_dis_total_cost,0),2) dr_ware_dis_total_cost,
round(ifnull(warehouse_cost,0),2) warehouse_cost
from logpm_expense_warehouse_day
<where>
<if test="expenseWarehouseDay.startDate != null and expenseWarehouseDay.startDate != ''">
and statistical_time >= #{expenseWarehouseDay.startDate}
</if>
<if test="expenseWarehouseDay.endDate != null and expenseWarehouseDay.endDate != ''">
and statistical_time <![CDATA[ <= ]]> #{expenseWarehouseDay.endDate}
</if>
<if test="expenseWarehouseDay.warehouseName != null and expenseWarehouseDay.warehouseName != ''">
and warehouse_name in
<foreach collection="expenseWarehouseDay.warehouseName.split(',')" item="item" separator="," open="("
close=")">
#{item}
</foreach>
</if>
</where>
</select>
<select id="statisticsMonthWarehouseExpense" resultType="com.logpm.statistics.entity.ExpenseWarehouseMonthEntity">
select t.warehouse_name,
t.cost_settlement_year,
t.cost_settlement_month,
concat(t.cost_settlement_year,'-',t.cost_settlement_month) costSettlement,
sum(ifnull(t.monthly_rent,0)) monthly_rent,
sum(ifnull(t.total_quantity_issued,0)) total_quantity_issued,
sum(ifnull(t.customer_leased_area,0)) customer_leased_area,
sum(ifnull(t.customer_monthly_rent,0)) customer_monthly_rent,
sum(ifnull(t.rented_items_dispatched_quantity,0)) rented_items_dispatched_quantity,
sum(ifnull(t.customer_rented_item_cost_per_unit,0)) customer_rented_item_cost_per_unit,
sum(ifnull(t.customer_total_leasing_cost,0)) customer_total_leasing_cost,
sum(ifnull(t.temporary_turnover_quantity,0)) temporary_turnover_quantity,
sum(ifnull(t.temporary_turnover_cost_per_item,0))temporary_turnover_cost_per_item,
sum(ifnull(t.total_temporary_turnover_cost,0)) total_temporary_turnover_cost,
sum(ifnull(t.dr_ware_dis_number,0)) dr_ware_dis_number,
sum(ifnull(t.dr_ware_dis_cost_per_unit,0)) dr_ware_dis_cost_per_unit,
sum(ifnull(t.dr_ware_dis_total_cost,0)) dr_ware_dis_total_cost,
sum(ifnull(t.consignment_storage,0)) consignment_storage,
sum(ifnull(t.total_cost_of_consignment_storage,0)) total_cost_of_consignment_storage,
sum(ifnull(t.consignment_withdrawal,0)) consignment_withdrawal,
sum(ifnull(t.total_cost_of_consignment_withdrawal,0)) total_cost_of_consignment_withdrawal,
sum(ifnull(t.total_cost_of_agency_operations,0)) total_cost_of_agency_operations,
sum(ifnull(t.total_warehouse_cost,0)) total_warehouse_cost
select t.warehouse_name,t.business_unit,
t.statistical_year,
t.statistical_month,
concat(t.statistical_year,'-',t.statistical_month) statisticalTime,
round(sum(ifnull(t.daily_rent,0)),2) monthlyRent,
sum(floor(ifnull(t.total_out_quantity,0))) totalOutQuantity,
sum(floor(ifnull(t.customer_rental_out_quantity,0))) customerRentalOutQuantity,
round(sum(ifnull(t.customer_daily_rent,0)),2) customerMonthlyRent,
round(sum(ifnull(t.customer_total_rental_cost,0)),2) customerTotalRentalCost,
round(sum(ifnull(t.customer_rental_unit_cost,0)),2) customerRentalUnitCost,
sum(floor(ifnull(t.temporary_turnover_quantity,0))) temporary_turnover_quantity,
round(sum(ifnull(t.temporary_turnover_unit_cost,0)),2) temporaryTurnoverUnitCost,
round(sum(ifnull(t.temporary_turnover_total_cost,0)),2) temporaryTurnoverTotalCost,
sum(floor(ifnull(t.dr_ware_dis_number,0))) dr_ware_dis_number,
round(sum(ifnull(t.dr_ware_dis_cost_per_unit,0)),2) dr_ware_dis_cost_per_unit,
round(sum(ifnull(t.dr_ware_dis_total_cost,0)),2) dr_ware_dis_total_cost,
round(sum(ifnull(t.warehouse_cost,0)),2) warehouseCost
from logpm_expense_warehouse_day t
where t.cost_settlement_year = #{year} and t.cost_settlement_month = #{month}
group by t.cost_settlement_year,t.cost_settlement_month,t.warehouse_name
where t.statistical_year = #{year} and t.statistical_month = #{month}
group by t.statistical_year,t.statistical_month,t.warehouse_name,t.business_unit
</select>
</mapper>

12
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehouseMonthMapper.java

@ -21,6 +21,7 @@ import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.entity.ExpenseWarehouseMonthEntity;
import com.logpm.statistics.excel.ExpenseWarehouseMonthExcel;
import com.logpm.statistics.query.ExpenseWarehouseMonthQuery;
import com.logpm.statistics.vo.ExpenseWarehouseMonthVO;
import org.apache.ibatis.annotations.Param;
@ -41,15 +42,6 @@ public interface ExpenseWarehouseMonthMapper extends BaseMapper<ExpenseWarehouse
* @param vo
* @return
*/
List<ExpenseWarehouseMonthVO> selectExpenseWarehouseMonthPage(@Param("page") IPage page, @Param("vo") ExpenseWarehouseMonthVO vo);
/**
* 获取导出数据
*
* @param queryWrapper
* @return
*/
List<ExpenseWarehouseMonthExcel> exportExpenseWarehouseMonth(@Param("ew") Wrapper<ExpenseWarehouseMonthEntity> queryWrapper);
List<ExpenseWarehouseMonthVO> selectExpenseWarehouseMonthPage(@Param("page") IPage page, @Param("vo") ExpenseWarehouseMonthQuery vo);
}

14
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehouseMonthMapper.xml

@ -7,18 +7,18 @@
</resultMap>
<select id="selectExpenseWarehouseMonthPage" resultMap="expenseWarehouseMonthResultMap">
<select id="selectExpenseWarehouseMonthPage" resultType="com.logpm.statistics.vo.ExpenseWarehouseMonthVO">
select * from logpm_expense_warehouse_month
where is_deleted = 0
<if test="vo.startDateQuery != null and vo.startDateQuery != ''">
and cost_settlement >= #{vo.startDateQuery}
<if test="vo.startDate != null and vo.startDate != ''">
and statistical_time >= #{vo.startDate}
</if>
<if test="vo.endDateQuery != null and vo.endDateQuery != ''">
and cost_settlement <![CDATA[ <= ]]> #{vo.endDateQuery}
<if test="vo.endDate != null and vo.endDate != ''">
and statistical_time <![CDATA[ <= ]]> #{vo.endDate}
</if>
<if test="vo.warehouseNameQuery != null and vo.warehouseNameQuery != ''">
<if test="vo.warehouseName != null and vo.warehouseName != ''">
and warehouse_name in
<foreach collection="vo.warehouseNameQuery.split(',')" item="item" separator="," open="(" close=")">
<foreach collection="vo.warehouseName.split(',')" item="item" separator="," open="(" close=")">
#{item}
</foreach>
</if>

37
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehousePackageDayMapper.java

@ -0,0 +1,37 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.statistics.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.entity.ExpenseWarehousePackageDayEntity;
import com.logpm.statistics.query.ExpenseWarehouseTransitMonthQuery;
import com.logpm.statistics.vo.ExpenseWarehouseTransitMonthVO;
import org.apache.ibatis.annotations.Param;
import java.util.List;
/**
* 包件日仓储成本 Mapper 接口
*
* @author zqb
* @since 2024-07-17
*/
public interface ExpenseWarehousePackageDayMapper extends BaseMapper<ExpenseWarehousePackageDayEntity> {
List<ExpenseWarehouseTransitMonthVO> transitPage(@Param("page") IPage<ExpenseWarehouseTransitMonthVO> page, @Param("query") ExpenseWarehouseTransitMonthQuery query);
}

12
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/ExpenseWarehousePackageDayMapper.xml

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.logpm.statistics.mapper.ExpenseWarehousePackageDayMapper">
<!-- 通用查询映射结果 -->
<resultMap id="expenseWarehouseMonthResultMap" type="com.logpm.statistics.entity.ExpenseWarehouseMonthEntity">
</resultMap>
<select id="transitPage" resultType="com.logpm.statistics.vo.ExpenseWarehouseTransitMonthVO">
</select>
</mapper>

3
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/StatisticsOrderInfoMapper.java

@ -28,6 +28,7 @@ public interface StatisticsOrderInfoMapper extends BaseMapper<StatisticsOrderInf
StatisticsPackageFeeInfoVO findPackageListByOrderIds(@Param("orderInfoIds") List<Long> orderInfoIdsList);
List<StatisticsPackageFeeInfoVO> findPackageListByOrderIdsGroupById(@Param("orderInfoIds") List<Long> orderInfoIdList);
List<StatisticsPackageFeeInfoVO> findPackageListByOrderIdsGroupByWaybillId(@Param("waybillIds") Set<Long> orderInfoIdList);
List<Long> findOrderInfoIdListByReconciliationOrderIds(@Param("reconciliationOrderIds") List<Long> reconciliationOrderIds);
@ -48,4 +49,6 @@ public interface StatisticsOrderInfoMapper extends BaseMapper<StatisticsOrderInf
void deleteDataByWaybillId(@Param("waybillId") Long waybillId);
List<AdvanceDetailDTO> selectAdvinceDetail(@Param("waybillIds") Set<Long> waybillIds, @Param("orderCodes") Set<String> orderCodes);
IPage<StatisticsOrderInfoVO> pageList2B(IPage<Object> page, @Param("param") MerchantStatisticsDTO merchantStatisticsDTO);
}

176
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/mapper/StatisticsOrderInfoMapper.xml

@ -498,6 +498,52 @@
group by lstp.order_info_id
</select>
<select id="findPackageListByOrderIdsGroupByWaybillId" resultType="com.logpm.statistics.vo.StatisticsPackageFeeInfoVO">
select
lstp.waybill_id,
GROUP_CONCAT(DISTINCT lswp.product_name ORDER BY lswp.product_name) goodsName,
IFNULL(sum(lstp.num),0) totalNum,
IFNULL(sum(lstp.weight),0) totalWeight,
IFNULL(sum(lstp.volume),0) totalVolume,
IFNULL(sum(lstp.system_freight_price),0)+IFNULL(sum(lstp.system_pickup_price),0)+IFNULL(sum(lswp.warehouse_service_fee),0)+IFNULL(sum(lsdp.delivery_service_fee),0)
sysTotalFee,
IFNULL(sum(lstp.freight_price),0)+IFNULL(sum(lstp.pickup_price),0)+IFNULL(sum(lswp.warehouse_service_fee),0)+IFNULL(sum(lsdp.delivery_service_fee),0)
totalFee,
IFNULL(sum(lstp.system_freight_price),0) systemFreightPrice,
IFNULL(sum(lstp.freight_price),0) freightPrice,
IFNULL(sum(lstp.system_pickup_price),0) systemPickupPrice,
IFNULL(sum(lstp.pickup_price),0) pickupPrice,
IFNULL(sum(lswp.warehouse_service_fee),0) warehouseServiceFee,
IFNULL(sum(lswp.warehouse_fee),0) warehouseFee,
IFNULL(sum(lswp.warehouse_manage_fee),0) warehouseManageFee,
IFNULL(sum(lswp.warehouse_sorting_fee),0) warehouseSortingFee,
IFNULL(sum(lswp.warehouse_operating_fee),0) warehouseOperatingFee,
IFNULL(sum(lsdp.system_delivery_fee),0) systemDeliveryFee,
IFNULL(sum(lsdp.delivery_service_fee),0) deliveryServiceFee,
IFNULL(sum(lsdp.delivery_fee),0) deliveryFee,
IFNULL(sum(lsdp.delivery_loading_fee),0) deliveryLoadingFee,
IFNULL(sum(lsdp.delivery_sorting_fee),0) deliverySortingFee,
IFNULL(sum(lsdp.delivery_upfloor_fee),0) deliveryUpfloorFee,
IFNULL(sum(lsdp.delivery_move_fee),0) deliveryMoveFee,
IFNULL(sum(lsdp.delivery_other_fee),0) deliveryOtherFee,
IFNULL(sum(lsdp.delivery_crossing_fee),0) deliveryCrossingFee,
IFNULL(sum(lsdp.sign_num),0) signNum,
max(lsdp.sign_time) signTime
from logpm_statistics_trunkline_package lstp
left join logpm_statistics_warehouse_package lswp on lswp.order_info_id = lstp.order_info_id and
IFNULL(lswp.order_package_code,'0') = IFNULL(lstp.order_package_code,'0') and IFNULL(lswp.product_id,1) =
IFNULL(lstp.product_id,1)
left join logpm_statistics_distribution_package lsdp on lsdp.order_info_id = lswp.order_info_id and
IFNULL(lsdp.order_package_code,'0') = IFNULL(lswp.order_package_code,'0') and IFNULL(lswp.product_id,1) =
IFNULL(lsdp.product_id,1)
where lstp.waybill_id in
<foreach collection="waybillIds" item="item" open="(" separator="," close=")">
#{item}
</foreach>
group by lstp.waybill_id
</select>
<select id="findOrderInfoIdListByReconciliationOrderIds" resultType="Long">
select id
from logpm_statistics_order_info lsoi
@ -577,6 +623,136 @@
#{item}
</foreach>
</select>
<select id="pageList2B" resultType="com.logpm.statistics.vo.StatisticsOrderInfoVO">
select lsoi.id orderInfoId,
lsoi.brand_id brandId,
lsoi.brand brand,
lsoi.waybill_id waybillId,
lsoi.waybill_no waybillNo,
lsoi.order_code orderCode,
lsoi.type_service typeService,
lww.shipper shipper,
lww.shipper_name shipperPerson,
lww.shipper_mobile shipperMobile,
lww.shipper_address shipperAddress,
lww.consignee consignee,
lww.consignee_name consigneePerson,
lww.consignee_mobile consigneeMobile,
lww.consignee_address consigneeAddress,
case lww.waybill_status
when 100 then 2
when 90 then 1
else 0
end
as signStatus,
lww.sign_time signDate,
lww.create_time openTime,
lww.departure departure,
lww.destination destination,
lsoi.departure_warehouse_id departureWarehouseId,
lsoi.departure_warehouse_name departureWarehouseName,
lsoi.destination_warehouse_id destinationWarehouseId,
lsoi.destination_warehouse_name destinationWarehouseName,
lww.delivery_method deliveryMethod,
lww.customer_train customerTrain,
lww.pay_type payType,
lww.pay_way payWay,
lsoi.create_reconciliation_order_status createReconciliationOrderStatus,
lsoi.create_reconciliation_user_name createReconciliationUserName,
lsoi.create_reconciliation_date createReconciliationDate,
lsoi.cycle cycle,
lsoi.warehouse_fee_interval warehouseFeeInterval,
lsoi.sync_fee_status syncFeeStatus,
lsoi.sync_fee_date syncFeeDate,
lbc.clean_obj_type cleanObjType
from logpm_statistics_order_info lsoi
left join logpm_basicdata_client lbc on lbc.id = lsoi.consignee_id
left join logpm_warehouse_waybill lww on lww.id = lsoi.waybill_id
where 1=1
and lsoi.create_reconciliation_order_status = 0
<if test="param.listType == 1">
and lsoi.type_service != '2'
</if>
<if test="param.listType == 2">
and lsoi.type_service = '2'
</if>
<if test="param.consignee != null and param.consignee != '' ">
and Locate(#{param.consignee},lww.consignee) > 0
</if>
<if test="param.confirmStatisticsOrder != null">
and lsoi.confirm_statistics_order = #{param.confirmStatisticsOrder}
</if>
<if test="param.syncFeeSstatus != null">
and lsoi.sync_fee_status = #{param.syncFeeSstatus}
</if>
<if test="param.signStatus != null">
and lsoi.sign_status = #{param.signStatus}
</if>
<if test="param.waybillNo != null and param.waybillNo != '' ">
and Locate(#{param.waybillNo},lww.waybill_no) > 0
</if>
<if test="param.orderCode != null and param.orderCode != '' ">
and Locate(#{param.orderCode},lww.order_no) > 0
</if>
<if test="param.shipper != null and param.shipper != '' ">
and Locate(#{param.shipper},lww.shipper) > 0
</if>
<if test="param.departureWarehouseName != null and param.departureWarehouseName != '' ">
and Locate(#{param.departureWarehouseName},lsoi.departure_warehouse_name) > 0
</if>
<if test="param.destinationWarehouseName != null and param.destinationWarehouseName != '' ">
and Locate(#{param.destinationWarehouseName},lsoi.destination_warehouse_name) > 0
</if>
<if test="param.typeService != null">
and lsoi.type_service = #{param.typeService}
</if>
<if test="param.openTimeStart != null">
and lww.document_making_time &gt;= #{param.openTimeStart}
</if>
<if test="param.openTimeEnd != null">
and lww.document_making_time &lt;= #{param.openTimeEnd}
</if>
<if test="param.signTimeStart != null">
and lsoi.sign_date &gt;= #{param.signTimeStart}
</if>
<if test="param.signTimeEnd != null">
and lsoi.sign_date &lt;= #{param.signTimeEnd}
</if>
<if test="param.syncFeeDateStart != null">
and lsoi.sync_fee_date &gt;= #{param.syncFeeDateStart}
</if>
<if test="param.syncFeeDateEnd != null">
and lsoi.sync_fee_date &lt;= #{param.syncFeeDateEnd}
</if>
<if test="param.shipperPerson != null and param.shipperPerson != '' ">
and Locate(#{param.shipperPerson},lww.shipper_person) > 0
</if>
<if test="param.shipperMoblie != null and param.shipperMoblie != '' ">
and Locate(#{param.shipperMoblie},lww.shipper_mobile) > 0
</if>
<if test="param.consigneePerson != null and param.consigneePerson != '' ">
and Locate(#{param.consigneePerson},lww.consignee_person) > 0
</if>
<if test="param.consigneeMobile != null and param.consigneeMobile != '' ">
and Locate(#{param.consigneeMobile},lww.consignee_mobile) > 0
</if>
<if test="param.cleanObjType != null and param.cleanObjType != '' ">
and lbc.clean_obj_type = #{param.cleanObjType}
</if>
<if test="param.payType != null and param.payType != '' ">
and lww.pay_type = #{param.payType}
</if>
<if test="param.payWay != null and param.payWay != '' ">
and lww.pay_way = #{param.payWay}
</if>
and lsoi.destination_warehouse_id in
<foreach collection="param.warehouseIds" item="item" open="(" separator="," close=")">
#{item}
</foreach>
group by lsoi.waybill_id
</select>
<delete id="deleteDataByWaybillId" >

17
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/query/ExpenseWarehouseDayQuery.java

@ -0,0 +1,17 @@
package com.logpm.statistics.query;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.mp.support.Query;
@Data
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseDayQuery extends Query {
@ApiModelProperty(value = "开始时间 年-月-日")
private String startDate;
@ApiModelProperty(value = "结束时间 年-月-日")
private String endDate;
@ApiModelProperty(value = "仓库 A,B,C")
private String warehouseName;
}

17
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/query/ExpenseWarehouseMonthQuery.java

@ -0,0 +1,17 @@
package com.logpm.statistics.query;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.mp.support.Query;
@Data
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseMonthQuery extends Query {
@ApiModelProperty(value = "开始时间 年-月-日")
private String startDate;
@ApiModelProperty(value = "结束时间 年-月-日")
private String endDate;
@ApiModelProperty(value = "仓库 A,B,C")
private String warehouseName;
}

20
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/query/ExpenseWarehouseOrderQuery.java

@ -0,0 +1,20 @@
package com.logpm.statistics.query;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.mp.support.Query;
@Data
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseOrderQuery extends Query {
@ApiModelProperty(value = "仓库 A,B,C")
private String warehouseName;
@ApiModelProperty(value = "订单号")
private String orderCode;
@ApiModelProperty(value = "运单号")
private String shipmentNumber;
@ApiModelProperty(value = "复核状态 已完成 未完成")
private String reviewStatus;
}

11
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/query/ExpenseWarehousePackageDayQuery.java

@ -0,0 +1,11 @@
package com.logpm.statistics.query;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.mp.support.Query;
@Data
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehousePackageDayQuery extends Query {
}

11
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/query/ExpenseWarehouseTransitMonthQuery.java

@ -0,0 +1,11 @@
package com.logpm.statistics.query;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.mp.support.Query;
@Data
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseTransitMonthQuery extends Query {
}

30
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/IExpenseOrderWarehouseTotalService.java

@ -16,13 +16,13 @@
*/
package com.logpm.statistics.service;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.logpm.statistics.entity.ExpenseOrderWarehouseTotalEntity;
import com.logpm.statistics.vo.ExpenseOrderWarehouseTotalVO;
import com.logpm.statistics.excel.ExpenseOrderWarehouseTotalExcel;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.entity.ExpenseWarehouseOrderEntity;
import com.logpm.statistics.query.ExpenseWarehouseOrderQuery;
import com.logpm.statistics.vo.ExpenseWarehouseOrderVO;
import org.springblade.core.mp.base.BaseService;
import java.util.List;
import javax.servlet.http.HttpServletResponse;
/**
* 订单总仓储成本明细 服务类
@ -30,23 +30,9 @@ import java.util.List;
* @author BladeX
* @since 2024-07-16
*/
public interface IExpenseOrderWarehouseTotalService extends BaseService<ExpenseOrderWarehouseTotalEntity> {
/**
* 自定义分页
*
* @param page
* @param expenseOrderWarehouseTotal
* @return
*/
IPage<ExpenseOrderWarehouseTotalVO> selectExpenseOrderWarehouseTotalPage(IPage<ExpenseOrderWarehouseTotalVO> page, ExpenseOrderWarehouseTotalVO expenseOrderWarehouseTotal);
public interface IExpenseOrderWarehouseTotalService extends BaseService<ExpenseWarehouseOrderEntity> {
/**
* 导出数据
*
* @param queryWrapper
* @return
*/
List<ExpenseOrderWarehouseTotalExcel> exportExpenseOrderWarehouseTotal(Wrapper<ExpenseOrderWarehouseTotalEntity> queryWrapper);
IPage<ExpenseWarehouseOrderVO> orderPage(ExpenseWarehouseOrderQuery query);
void exporOrder(HttpServletResponse response, ExpenseWarehouseOrderQuery query);
}

34
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/IExpenseWarehouseDayService.java

@ -16,14 +16,14 @@
*/
package com.logpm.statistics.service;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.entity.ExpenseWarehouseDayEntity;
import com.logpm.statistics.entity.ExpenseWarehouseMonthEntity;
import com.logpm.statistics.excel.ExpenseWarehouseDayExcel;
import com.logpm.statistics.query.ExpenseWarehouseDayQuery;
import com.logpm.statistics.vo.ExpenseWarehouseDayVO;
import org.springblade.core.mp.base.BaseService;
import javax.servlet.http.HttpServletResponse;
import java.util.List;
/**
@ -34,22 +34,12 @@ import java.util.List;
*/
public interface IExpenseWarehouseDayService extends BaseService<ExpenseWarehouseDayEntity> {
/**
* 自定义分页
*
* @param page
* @param expenseWarehouseDay
* @return
*/
IPage<ExpenseWarehouseDayVO> selectExpenseWarehouseDayPage(IPage<ExpenseWarehouseDayVO> page, ExpenseWarehouseDayVO expenseWarehouseDay);
/**
* 导出数据
*
* @param queryWrapper
* @return
*/
List<ExpenseWarehouseDayExcel> exportExpenseWarehouseDay(Wrapper<ExpenseWarehouseDayEntity> queryWrapper);
* 分页
* @param query
* @Return com.baomidou.mybatisplus.core.metadata.IPage<com.logpm.statistics.vo.ExpenseWarehouseDayVO>
* @Author zqb 2024/11/27
**/
IPage<ExpenseWarehouseDayVO> dayPage(ExpenseWarehouseDayQuery query);
/**
* 按年月统计仓储成本数据
@ -60,4 +50,12 @@ public interface IExpenseWarehouseDayService extends BaseService<ExpenseWarehous
**/
List<ExpenseWarehouseMonthEntity> statisticsMonthWarehouseExpense(int year, int month);
/**
* 导出日仓储成本统计表
* @param response
* @param query
* @Return void
* @Author zqb 2024/11/27
**/
void exporDay(HttpServletResponse response, ExpenseWarehouseDayQuery query);
}

26
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/IExpenseWarehouseMonthService.java

@ -16,13 +16,13 @@
*/
package com.logpm.statistics.service;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.entity.ExpenseWarehouseMonthEntity;
import com.logpm.statistics.query.ExpenseWarehouseMonthQuery;
import com.logpm.statistics.vo.ExpenseWarehouseMonthVO;
import com.logpm.statistics.excel.ExpenseWarehouseMonthExcel;
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.springblade.core.mp.base.BaseService;
import java.util.List;
import javax.servlet.http.HttpServletResponse;
/**
* 月度仓储成本统计表 服务类
@ -31,22 +31,8 @@ import java.util.List;
* @since 2024-07-17
*/
public interface IExpenseWarehouseMonthService extends BaseService<ExpenseWarehouseMonthEntity> {
/**
* 自定义分页
*
* @param page
* @param expenseWarehouseMonth
* @return
*/
IPage<ExpenseWarehouseMonthVO> selectExpenseWarehouseMonthPage(IPage<ExpenseWarehouseMonthVO> page, ExpenseWarehouseMonthVO expenseWarehouseMonth);
/**
* 导出数据
*
* @param queryWrapper
* @return
*/
List<ExpenseWarehouseMonthExcel> exportExpenseWarehouseMonth(Wrapper<ExpenseWarehouseMonthEntity> queryWrapper);
IPage<ExpenseWarehouseMonthVO> monthPage(ExpenseWarehouseMonthQuery query);
void exporMonth(HttpServletResponse response, ExpenseWarehouseMonthQuery query);
}

37
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/IExpenseWarehousePackageDayService.java

@ -0,0 +1,37 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.statistics.service;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.entity.ExpenseWarehousePackageDayEntity;
import com.logpm.statistics.query.ExpenseWarehouseTransitMonthQuery;
import com.logpm.statistics.vo.ExpenseWarehouseDayVO;
import com.logpm.statistics.vo.ExpenseWarehousePackageDayVO;
import com.logpm.statistics.vo.ExpenseWarehouseTransitMonthVO;
import org.springblade.core.mp.base.BaseService;
/**
* 日仓储成本统计表 服务类
*
* @author zqb
* @since 2024-09-23
*/
public interface IExpenseWarehousePackageDayService extends BaseService<ExpenseWarehousePackageDayEntity> {
IPage<ExpenseWarehouseTransitMonthVO> transitPage(ExpenseWarehouseTransitMonthQuery query);
}

6
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/IStatisticsOrderInfoService.java

@ -56,4 +56,10 @@ public interface IStatisticsOrderInfoService extends BaseService<StatisticsOrder
void orderInfoService(Long waybillId);
R createReconciliationWaybillId(List<Long> waybillIds);
R createFinishWaybillId(List<Long> waybillIds);
boolean calculateRealCostByWaybillId(Long id);
}

40
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/impl/ExpenseOrderWarehouseTotalServiceImpl.java

@ -16,15 +16,18 @@
*/
package com.logpm.statistics.service.impl;
import com.logpm.statistics.entity.ExpenseOrderWarehouseTotalEntity;
import com.logpm.statistics.vo.ExpenseOrderWarehouseTotalVO;
import com.logpm.statistics.excel.ExpenseOrderWarehouseTotalExcel;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.entity.ExpenseWarehouseOrderEntity;
import com.logpm.statistics.mapper.ExpenseOrderWarehouseTotalMapper;
import com.logpm.statistics.query.ExpenseWarehouseOrderQuery;
import com.logpm.statistics.service.IExpenseOrderWarehouseTotalService;
import org.springframework.stereotype.Service;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.vo.ExpenseWarehouseOrderVO;
import org.springblade.core.excel.util.ExcelUtil;
import org.springblade.core.mp.base.BaseServiceImpl;
import org.springblade.core.mp.support.Condition;
import org.springframework.stereotype.Service;
import javax.servlet.http.HttpServletResponse;
import java.util.List;
/**
@ -34,21 +37,20 @@ import java.util.List;
* @since 2024-07-16
*/
@Service
public class ExpenseOrderWarehouseTotalServiceImpl extends BaseServiceImpl<ExpenseOrderWarehouseTotalMapper, ExpenseOrderWarehouseTotalEntity> implements IExpenseOrderWarehouseTotalService {
@Override
public IPage<ExpenseOrderWarehouseTotalVO> selectExpenseOrderWarehouseTotalPage(IPage<ExpenseOrderWarehouseTotalVO> page, ExpenseOrderWarehouseTotalVO expenseOrderWarehouseTotal) {
return page.setRecords(baseMapper.selectExpenseOrderWarehouseTotalPage(page, expenseOrderWarehouseTotal));
}
public class ExpenseOrderWarehouseTotalServiceImpl extends BaseServiceImpl<ExpenseOrderWarehouseTotalMapper, ExpenseWarehouseOrderEntity> implements IExpenseOrderWarehouseTotalService {
@Override
public List<ExpenseOrderWarehouseTotalExcel> exportExpenseOrderWarehouseTotal(Wrapper<ExpenseOrderWarehouseTotalEntity> queryWrapper) {
List<ExpenseOrderWarehouseTotalExcel> expenseOrderWarehouseTotalList = baseMapper.exportExpenseOrderWarehouseTotal(queryWrapper);
//expenseOrderWarehouseTotalList.forEach(expenseOrderWarehouseTotal -> {
// expenseOrderWarehouseTotal.setTypeName(DictCache.getValue(DictEnum.YES_NO, ExpenseOrderWarehouseTotal.getType()));
//});
return expenseOrderWarehouseTotalList;
public IPage<ExpenseWarehouseOrderVO> orderPage(ExpenseWarehouseOrderQuery query) {
IPage<ExpenseWarehouseOrderVO> page = Condition.getPage(query);
return page.setRecords(baseMapper.selectExpenseOrderWarehouseTotalPage(page, query));
}
@Override
public void exporOrder(HttpServletResponse response, ExpenseWarehouseOrderQuery query) {
IPage<ExpenseWarehouseOrderVO> page = Condition.getPage(query);
page.setSize(-1);
page.setCurrent(1);
List<ExpenseWarehouseOrderVO> list = baseMapper.selectExpenseOrderWarehouseTotalPage(page, query);
ExcelUtil.export(response, list, ExpenseWarehouseOrderVO.class);
}
}

32
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/impl/ExpenseWarehouseDayServiceImpl.java

@ -17,17 +17,19 @@
package com.logpm.statistics.service.impl;
import cn.hutool.core.util.ObjectUtil;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.entity.ExpenseWarehouseDayEntity;
import com.logpm.statistics.entity.ExpenseWarehouseMonthEntity;
import com.logpm.statistics.excel.ExpenseWarehouseDayExcel;
import com.logpm.statistics.mapper.ExpenseWarehouseDayMapper;
import com.logpm.statistics.query.ExpenseWarehouseDayQuery;
import com.logpm.statistics.service.IExpenseWarehouseDayService;
import com.logpm.statistics.vo.ExpenseWarehouseDayVO;
import org.springblade.core.excel.util.ExcelUtil;
import org.springblade.core.mp.base.BaseServiceImpl;
import org.springblade.core.mp.support.Condition;
import org.springframework.stereotype.Service;
import javax.servlet.http.HttpServletResponse;
import java.util.Collections;
import java.util.List;
@ -41,26 +43,26 @@ import java.util.List;
public class ExpenseWarehouseDayServiceImpl extends BaseServiceImpl<ExpenseWarehouseDayMapper, ExpenseWarehouseDayEntity> implements IExpenseWarehouseDayService {
@Override
public IPage<ExpenseWarehouseDayVO> selectExpenseWarehouseDayPage(IPage<ExpenseWarehouseDayVO> page, ExpenseWarehouseDayVO expenseWarehouseDay) {
return page.setRecords(baseMapper.selectExpenseWarehouseDayPage(page, expenseWarehouseDay));
}
@Override
public List<ExpenseWarehouseDayExcel> exportExpenseWarehouseDay(Wrapper<ExpenseWarehouseDayEntity> queryWrapper) {
List<ExpenseWarehouseDayExcel> expenseWarehouseDayList = baseMapper.exportExpenseWarehouseDay(queryWrapper);
//expenseWarehouseDayList.forEach(expenseWarehouseDay -> {
// expenseWarehouseDay.setTypeName(DictCache.getValue(DictEnum.YES_NO, ExpenseWarehouseDay.getType()));
//});
return expenseWarehouseDayList;
public IPage<ExpenseWarehouseDayVO> dayPage(ExpenseWarehouseDayQuery query) {
IPage<ExpenseWarehouseDayVO> page = Condition.getPage(query);
return page.setRecords(baseMapper.selectExpenseWarehouseDayPage(page, query));
}
@Override
public List<ExpenseWarehouseMonthEntity> statisticsMonthWarehouseExpense(int year, int month) {
if(ObjectUtil.isEmpty(year) || ObjectUtil.isEmpty(month)){
if (ObjectUtil.isEmpty(year) || ObjectUtil.isEmpty(month)) {
return Collections.emptyList();
}
return baseMapper.statisticsMonthWarehouseExpense(year, month);
}
@Override
public void exporDay(HttpServletResponse response, ExpenseWarehouseDayQuery query) {
IPage<ExpenseWarehouseDayVO> page = Condition.getPage(query);
page.setSize(-1);
page.setCurrent(1);
List<ExpenseWarehouseDayVO> list = baseMapper.selectExpenseWarehouseDayPage(page, query);
ExcelUtil.export(response, list, ExpenseWarehouseDayVO.class);
}
}

31
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/impl/ExpenseWarehouseMonthServiceImpl.java

@ -16,16 +16,18 @@
*/
package com.logpm.statistics.service.impl;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.entity.ExpenseWarehouseMonthEntity;
import com.logpm.statistics.excel.ExpenseWarehouseMonthExcel;
import com.logpm.statistics.mapper.ExpenseWarehouseMonthMapper;
import com.logpm.statistics.query.ExpenseWarehouseMonthQuery;
import com.logpm.statistics.service.IExpenseWarehouseMonthService;
import com.logpm.statistics.vo.ExpenseWarehouseMonthVO;
import org.springblade.core.excel.util.ExcelUtil;
import org.springblade.core.mp.base.BaseServiceImpl;
import org.springblade.core.mp.support.Condition;
import org.springframework.stereotype.Service;
import javax.servlet.http.HttpServletResponse;
import java.util.List;
/**
@ -37,21 +39,18 @@ import java.util.List;
@Service
public class ExpenseWarehouseMonthServiceImpl extends BaseServiceImpl<ExpenseWarehouseMonthMapper, ExpenseWarehouseMonthEntity> implements IExpenseWarehouseMonthService {
@Override
public IPage<ExpenseWarehouseMonthVO> selectExpenseWarehouseMonthPage(IPage<ExpenseWarehouseMonthVO> page, ExpenseWarehouseMonthVO expenseWarehouseMonth) {
// QueryWrapper<ExpenseWarehouseMonthVO> queryWrapper = QueryUtil.buildQueryWrapper(expenseWarehouseMonth, ExpenseWarehouseMonthVO.class);
// queryWrapper.lambda().eq(ExpenseWarehouseMonthVO::getIsDeleted, BladeConstant.DB_NOT_DELETED);
return page.setRecords(baseMapper.selectExpenseWarehouseMonthPage(page, expenseWarehouseMonth));
}
@Override
public IPage<ExpenseWarehouseMonthVO> monthPage(ExpenseWarehouseMonthQuery query) {
IPage<ExpenseWarehouseMonthVO> page = Condition.getPage(query);
return page.setRecords(baseMapper.selectExpenseWarehouseMonthPage(page, query));
}
@Override
public List<ExpenseWarehouseMonthExcel> exportExpenseWarehouseMonth(Wrapper<ExpenseWarehouseMonthEntity> queryWrapper) {
List<ExpenseWarehouseMonthExcel> expenseWarehouseMonthList = baseMapper.exportExpenseWarehouseMonth(queryWrapper);
//expenseWarehouseMonthList.forEach(expenseWarehouseMonth -> {
// expenseWarehouseMonth.setTypeName(DictCache.getValue(DictEnum.YES_NO, ExpenseWarehouseMonth.getType()));
//});
return expenseWarehouseMonthList;
public void exporMonth(HttpServletResponse response, ExpenseWarehouseMonthQuery query) {
IPage<ExpenseWarehouseMonthVO> page = Condition.getPage(query);
page.setSize(-1);
page.setCurrent(1);
List<ExpenseWarehouseMonthVO> list = baseMapper.selectExpenseWarehouseMonthPage(page, query);
ExcelUtil.export(response, list, ExpenseWarehouseMonthVO.class);
}
}

43
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/impl/ExpenseWarehousePackageDayServiceImpl.java

@ -0,0 +1,43 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.statistics.service.impl;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.statistics.entity.ExpenseWarehousePackageDayEntity;
import com.logpm.statistics.mapper.ExpenseWarehousePackageDayMapper;
import com.logpm.statistics.query.ExpenseWarehouseTransitMonthQuery;
import com.logpm.statistics.service.IExpenseWarehousePackageDayService;
import com.logpm.statistics.vo.ExpenseWarehouseTransitMonthVO;
import org.springblade.core.mp.base.BaseServiceImpl;
import org.springblade.core.mp.support.Condition;
import org.springframework.stereotype.Service;
/**
* 月度仓储成本统计表 服务实现类
*
* @author zqb
* @since 2024-07-17
*/
@Service
public class ExpenseWarehousePackageDayServiceImpl extends BaseServiceImpl<ExpenseWarehousePackageDayMapper, ExpenseWarehousePackageDayEntity> implements IExpenseWarehousePackageDayService {
@Override
public IPage<ExpenseWarehouseTransitMonthVO> transitPage(ExpenseWarehouseTransitMonthQuery query) {
IPage<ExpenseWarehouseTransitMonthVO> page = Condition.getPage(query);
return page.setRecords(baseMapper.transitPage(page, query));
}
}

791
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/service/impl/StatisticsOrderInfoServiceImpl.java

File diff suppressed because it is too large Load Diff

174
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseWarehouseDayVO.java

@ -16,10 +16,12 @@
*/
package com.logpm.statistics.vo;
import com.logpm.statistics.entity.ExpenseWarehouseDayEntity;
import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import java.math.BigDecimal;
/**
* 日仓储成本统计表 视图实体类
@ -28,13 +30,165 @@ import lombok.EqualsAndHashCode;
* @since 2024-09-23
*/
@Data
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseDayVO extends ExpenseWarehouseDayEntity {
public class ExpenseWarehouseDayVO {
private static final long serialVersionUID = 1L;
@ApiModelProperty(value = "开始时间 年-月-日")
private String startDateQuery;
@ApiModelProperty(value = "结束时间 年-月-日")
private String endDateQuery;
@ApiModelProperty(value = "仓库 A,B,C")
private String warehouseNameQuery;
/**
* 统计年
*/
@ApiModelProperty(value = "统计年")
@ExcelIgnore
private Integer statisticalYear;
/**
* 统计月
*/
@ApiModelProperty(value = "统计月")
@ExcelIgnore
private Integer statisticalMonth;
/**
* 统计日
*/
@ApiModelProperty(value = "统计日")
@ExcelIgnore
private Integer statisticalDay;
/**
* 目的仓
*/
@ApiModelProperty(value = "目的仓")
@ExcelProperty("目的仓")
private String warehouseName;
/**
* 统计日期
*/
@ApiModelProperty(value = "统计日期")
@ExcelProperty("统计日期")
private String statisticalTime;
/**
* 当月天数
*/
@ApiModelProperty(value = "当月天数")
@ExcelIgnore
private Integer dayNumber;
/**
* 事业线
*/
@ApiModelProperty(value = "事业线")
@ExcelIgnore
private String businessUnit;
/**
* 仓库总面积
*/
@ApiModelProperty(value = "仓库总面积(㎡)")
@ExcelProperty("仓库总面积")
private BigDecimal totalArea;
/**
* 仓库租金
*/
@ApiModelProperty(value = "仓库租金")
@ExcelProperty("仓库租金")
private BigDecimal rent;
/**
* 仓库月租金
*/
@ApiModelProperty(value = "仓库日租金")
@ExcelProperty("仓库日租金")
private BigDecimal dailyRent;
/**
* 出库总件数
*/
@ApiModelProperty(value = "出库总件数")
@ExcelProperty("出库总件数")
private Integer totalOutQuantity;
/**
* 客户租用面积
*/
@ApiModelProperty(value = "客户租用面积(㎡)")
@ExcelProperty("客户租用面积")
private BigDecimal customerRentalArea;
/**
* 客户月租金
*/
@ApiModelProperty(value = "客户租用月租金")
@ExcelProperty("客户租用月租金")
private BigDecimal customerMonthlyRent;
/**
* 客户日租金
*/
@ApiModelProperty(value = "客户租用日租金")
@ExcelProperty("客户租用日租金")
private BigDecimal customerDailyRent;
/**
* 租用出库件数
*/
@ApiModelProperty(value = "客户租用出库件数")
@ExcelProperty("客户租用出库件数")
private Integer customerRentalOutQuantity;
/**
* 客户租用单件成本
*/
@ApiModelProperty(value = "客户租用单件成本")
@ExcelProperty("客户租用单件成本")
private BigDecimal customerRentalUnitCost;
/**
* 客户租用总成本
*/
@ApiModelProperty(value = "客户租用总成本")
@ExcelProperty("客户租用总成本")
private BigDecimal customerTotalRentalCost;
/**
* 临时周转面积
*/
@ApiModelProperty(value = "临时周转面积")
@ExcelProperty("临时周转面积")
private BigDecimal temporaryTurnoverArea;
/**
* 临时周转件数
*/
@ApiModelProperty(value = "临时周转件数")
@ExcelProperty("临时周转件数")
private Integer temporaryTurnoverQuantity;
/**
* 临时周转单件成本
*/
@ApiModelProperty(value = "临时周转单件成本")
@ExcelProperty("临时周转单件成本")
private BigDecimal temporaryTurnoverUnitCost;
/**
* 临时周转总成本
*/
@ApiModelProperty(value = "临时周转总成本")
@ExcelProperty("临时周转总成本")
private BigDecimal temporaryTurnoverTotalCost;
/**
* 干仓配仓储面积
*/
@ApiModelProperty(value = "干仓配仓储面积")
@ExcelProperty("干仓配仓储面积")
private BigDecimal drWareDisArea;
/**
* 干仓配件数
*/
@ApiModelProperty(value = "干仓配件数")
@ExcelProperty("干仓配件数")
private Integer drWareDisNumber;
/**
* 干仓配单件成本
*/
@ApiModelProperty(value = "干仓配单件成本")
@ExcelProperty("干仓配单件成本")
private BigDecimal drWareDisCostPerUnit;
/**
* 干仓配仓储总成本
*/
@ApiModelProperty(value = "干仓配仓储总成本")
@ExcelProperty("干仓配仓储总成本")
private BigDecimal drWareDisTotalCost;
/**
* 仓库租赁总成本
*/
@ApiModelProperty(value = "仓库租赁总成本")
@ExcelProperty("仓库租赁总成本")
private BigDecimal warehouseCost;
}

124
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseWarehouseMonthVO.java

@ -16,11 +16,13 @@
*/
package com.logpm.statistics.vo;
import com.logpm.statistics.entity.ExpenseWarehouseMonthEntity;
import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import java.math.BigDecimal;
/**
* 月度仓储成本统计表 视图实体类
@ -29,22 +31,118 @@ import lombok.EqualsAndHashCode;
* @since 2024-07-17
*/
@Data
@EqualsAndHashCode(callSuper = true)
@ApiModel(value = "ExpenseOrderWarehouseMonth对象", description = "月度订单仓储成本明细")
public class ExpenseWarehouseMonthVO extends ExpenseWarehouseMonthEntity {
public class ExpenseWarehouseMonthVO {
private static final long serialVersionUID = 1L;
/**
* 成本结算时间
* 统计年
*/
@ApiModelProperty(value = "统计年")
@ExcelIgnore
private Integer statisticalYear;
/**
* 统计月
*/
@ApiModelProperty(value = "统计月")
@ExcelIgnore
private Integer statisticalMonth;
/**
* 目的仓
*/
@ApiModelProperty(value = "目的仓")
@ExcelProperty("目的仓")
private String warehouseName;
/**
* 日期
*/
@ApiModelProperty(value = "统计日期")
@ExcelProperty("统计日期")
private String statisticalTime;
/**
* 事业线
*/
@ApiModelProperty(value = "成本结算时间")
private String CostSettlementTime;
@ApiModelProperty(value = "事业线")
@ExcelIgnore
private String businessUnit;
@ApiModelProperty(value = "开始时间 年-月-日")
private String startDateQuery;
@ApiModelProperty(value = "结束时间 年-月-日")
private String endDateQuery;
@ApiModelProperty(value = "仓库 A,B,C")
private String warehouseNameQuery;
/**
* 仓库月租金
*/
@ApiModelProperty(value = "仓库月租金")
@ExcelProperty("仓库月租金")
private BigDecimal monthlyRent;
/**
* 出库总件数
*/
@ApiModelProperty(value = "出库总件数")
@ExcelProperty("出库总件数")
private Integer totalOutQuantity;
/**
* 客户月租金
*/
@ApiModelProperty(value = "客户租用月租金")
@ExcelProperty("客户租用月租金")
private BigDecimal customerMonthlyRent;
/**
* 租用出库件数
*/
@ApiModelProperty(value = "客户租用出库件数")
@ExcelProperty("客户租用出库件数")
private Integer customerRentalOutQuantity;
/**
* 客户租用单件成本
*/
@ApiModelProperty(value = "客户租用单件成本")
@ExcelProperty("客户租用单件成本")
private BigDecimal customerRentalUnitCost;
/**
* 客户租用总成本
*/
@ApiModelProperty(value = "客户租用总成本")
@ExcelProperty("客户租用总成本")
private BigDecimal customerTotalRentalCost;
/**
* 临时周转件数
*/
@ApiModelProperty(value = "临时周转件数")
@ExcelProperty("临时周转件数")
private Integer temporaryTurnoverQuantity;
/**
* 临时周转单件成本
*/
@ApiModelProperty(value = "临时周转单件成本")
@ExcelProperty("临时周转单件成本")
private BigDecimal temporaryTurnoverUnitCost;
/**
* 临时周转总成本
*/
@ApiModelProperty(value = "临时周转总成本")
@ExcelProperty("临时周转总成本")
private BigDecimal temporaryTurnoverTotalCost;
/**
* 干仓配件数
*/
@ApiModelProperty(value = "干仓配件数")
@ExcelProperty("干仓配件数")
private Integer drWareDisNumber;
/**
* 干仓配单件成本
*/
@ApiModelProperty(value = "干仓配单件成本")
@ExcelProperty("干仓配单件成本")
private BigDecimal drWareDisCostPerUnit;
/**
* 干仓配仓储总成本
*/
@ApiModelProperty(value = "干仓配仓储总成本")
@ExcelProperty("干仓配仓储总成本")
private BigDecimal drWareDisTotalCost;
/**
* 仓库租赁总成本
*/
@ApiModelProperty(value = "仓库租赁总成本")
@ExcelProperty("仓库租赁总成本")
private BigDecimal warehouseCost;
}

111
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseWarehouseOrderVO.java

@ -0,0 +1,111 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.statistics.vo;
import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import java.math.BigDecimal;
/**
* 订单总仓储成本明细 视图实体类
*
* @author BladeX
* @since 2024-07-16
*/
@Data
@ApiModel(value = "ExpenseOrderWarehouseMonth对象", description = "月度订单仓储成本明细")
public class ExpenseWarehouseOrderVO {
private static final long serialVersionUID = 1L;
/**
* 事业线
*/
@ApiModelProperty(value = "事业线")
@ExcelIgnore
private String businessUnit;
/**
* 目的仓
*/
@ApiModelProperty(value = "目的仓")
@ExcelProperty("目的仓")
private String warehouseName;
/**
* 订单编号
*/
@ApiModelProperty(value = "订单编号")
@ExcelProperty("订单编号")
private String orderCode;
/**
* 运单编号
*/
@ApiModelProperty(value = "运单编号")
@ExcelProperty("运单编号")
private String shipmentNumber;
/**
* 收货单位
*/
@ApiModelProperty(value = "收货单位")
@ExcelProperty("收货单位")
private String receivingUnit;
/**
* 发货单位
*/
@ApiModelProperty(value = "发货单位")
@ExcelProperty("发货单位")
private String shippingUnit;
/**
* 发货单位
*/
@ApiModelProperty(value = "配送类型")
@ExcelProperty("配送类型")
private String deliveryType;
/**
* 复核状态
*/
@ApiModelProperty(value = "复核状态 已完成 未完成")
@ExcelProperty("复核状态")
private String reviewStatus;
/**
* 发站仓
*/
@ApiModelProperty(value = "发站仓")
@ExcelProperty("发站仓")
private String originWarehouse;
/**
* 订单总件数
*/
@ApiModelProperty(value = "订单总件数")
@ExcelProperty("订单总件数")
private Integer totalNumber;
/**
* 出库件数
*/
@ApiModelProperty(value = "出库件数")
@ExcelProperty("出库件数")
private Integer outNumber;
/**
* 租赁成本
*/
@ApiModelProperty(value = "租赁成本")
@ExcelProperty("租赁成本")
private BigDecimal warehouseRentalCost;
}

14
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseOrderWarehouseTotalVO.java → blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseWarehousePackageDayVO.java

@ -16,21 +16,19 @@
*/
package com.logpm.statistics.vo;
import com.logpm.statistics.entity.ExpenseOrderWarehouseTotalEntity;
import io.swagger.annotations.ApiModel;
import com.logpm.statistics.entity.ExpenseWarehousePackageDayEntity;
import lombok.Data;
import lombok.EqualsAndHashCode;
/**
* 订单总仓储成本明细 视图实体类
* 包件日仓储成本报表 视图实体类
*
* @author BladeX
* @since 2024-07-16
* @author zqb
* @since 2024-09-23
*/
@Data
@EqualsAndHashCode(callSuper = true)
@ApiModel(value = "ExpenseOrderWarehouseMonth对象", description = "月度订单仓储成本明细")
public class ExpenseOrderWarehouseTotalVO extends ExpenseOrderWarehouseTotalEntity {
private static final long serialVersionUID = 1L;
public class ExpenseWarehousePackageDayVO extends ExpenseWarehousePackageDayEntity {
}

34
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/ExpenseWarehouseTransitMonthVO.java

@ -0,0 +1,34 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package com.logpm.statistics.vo;
import com.logpm.statistics.entity.ExpenseWarehouseTransitMonthEntity;
import lombok.Data;
import lombok.EqualsAndHashCode;
/**
* 月度仓储+ 视图实体类
*
* @author zqb
* @since 2024-09-23
*/
@Data
@EqualsAndHashCode(callSuper = true)
public class ExpenseWarehouseTransitMonthVO extends ExpenseWarehouseTransitMonthEntity {
}

1
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/vo/StatisticsPackageFeeInfoVO.java

@ -10,6 +10,7 @@ import java.util.Date;
public class StatisticsPackageFeeInfoVO implements Serializable {
private Long orderInfoId;
private Long waybillId;
private String goodsName;//物料品类

10
blade-service/logpm-statisticsdata/src/main/java/com/logpm/statistics/wrapper/ExpenseOrderWarehouseTotalWrapper.java

@ -18,8 +18,8 @@ package com.logpm.statistics.wrapper;
import org.springblade.core.mp.support.BaseEntityWrapper;
import org.springblade.core.tool.utils.BeanUtil;
import com.logpm.statistics.entity.ExpenseOrderWarehouseTotalEntity;
import com.logpm.statistics.vo.ExpenseOrderWarehouseTotalVO;
import com.logpm.statistics.entity.ExpenseWarehouseOrderEntity;
import com.logpm.statistics.vo.ExpenseWarehouseOrderVO;
import java.util.Objects;
/**
@ -28,15 +28,15 @@ import java.util.Objects;
* @author BladeX
* @since 2024-07-16
*/
public class ExpenseOrderWarehouseTotalWrapper extends BaseEntityWrapper<ExpenseOrderWarehouseTotalEntity, ExpenseOrderWarehouseTotalVO> {
public class ExpenseOrderWarehouseTotalWrapper extends BaseEntityWrapper<ExpenseWarehouseOrderEntity, ExpenseWarehouseOrderVO> {
public static ExpenseOrderWarehouseTotalWrapper build() {
return new ExpenseOrderWarehouseTotalWrapper();
}
@Override
public ExpenseOrderWarehouseTotalVO entityVO(ExpenseOrderWarehouseTotalEntity expenseOrderWarehouseTotal) {
ExpenseOrderWarehouseTotalVO expenseOrderWarehouseTotalVO = Objects.requireNonNull(BeanUtil.copy(expenseOrderWarehouseTotal, ExpenseOrderWarehouseTotalVO.class));
public ExpenseWarehouseOrderVO entityVO(ExpenseWarehouseOrderEntity expenseOrderWarehouseTotal) {
ExpenseWarehouseOrderVO expenseOrderWarehouseTotalVO = Objects.requireNonNull(BeanUtil.copy(expenseOrderWarehouseTotal, ExpenseWarehouseOrderVO.class));
//User createUser = UserCache.getUser(expenseOrderWarehouseTotal.getCreateUser());
//User updateUser = UserCache.getUser(expenseOrderWarehouseTotal.getUpdateUser());

161
blade-service/logpm-trunkline/src/main/java/com/logpm/trunkline/mq/waybil/StatusLogListener.java

@ -0,0 +1,161 @@
package com.logpm.trunkline.mq.waybil;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import com.logpm.trunkline.dto.WaybillLogDTO;
import com.logpm.trunkline.feign.ITrunklineWaybillTrackClient;
import com.logpm.trunkline.mapper.TrunklineWaybillPackageMapper;
import com.logpm.trunkline.service.ITrunklineWaybillPackageService;
import com.logpm.trunkline.service.ITrunklineWaybillTrackService;
import lombok.AllArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springblade.common.constant.broadcast.FanoutConstants;
import org.springblade.common.enums.BizOperationEnums;
import org.springblade.common.model.DistributionReCheckSignVO;
import org.springblade.common.model.NodeFanoutMsg;
import org.springblade.common.model.PackageData;
import org.springblade.common.model.workNode.PickUpByReCheckVO;
import org.springframework.amqp.core.ExchangeTypes;
import org.springframework.amqp.rabbit.annotation.Exchange;
import org.springframework.amqp.rabbit.annotation.Queue;
import org.springframework.amqp.rabbit.annotation.QueueBinding;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;
import org.springframework.transaction.annotation.Transactional;
import java.util.*;
import java.util.stream.Collectors;
/**
* 运单日志和状态变更
*/
@Slf4j
@Component
@AllArgsConstructor
public class StatusLogListener {
private final ITrunklineWaybillTrackClient trunklineWaybillTrackClient ;
@RabbitListener(bindings = @QueueBinding(
value = @Queue(name = FanoutConstants.DeliveryOfPickup.BillSignReview.QUEUE.waybillStatusLog, durable = "true"),
exchange = @Exchange(name = FanoutConstants.DeliveryOfPickup.BillSignReview.EXCHANGE, type = ExchangeTypes.FANOUT)
))
@Transactional(rollbackFor = Exception.class)
public void statusPickUpLog(String msg) {
log.info("自提复核处理运单日志和状态: {}", msg);
if (StrUtil.isEmpty(msg)) {
return;
}
NodeFanoutMsg bean = JSONUtil.toBean(msg, NodeFanoutMsg.class);
Object main = bean.getMain();
JSONObject entries = JSONUtil.parseObj(main);
PickUpByReCheckVO vo = JSONUtil.toBean(entries, PickUpByReCheckVO.class);
Long warehouseId = bean.getWarehouseId();
BizOperationEnums bizOperation = bean.getBizOperation();
List<PackageData> details = vo.getPackageDataList();
// 按照运单号进行分组 后面的集合 按照创建时间进行排序
Map<String, List<PackageData>> map = details.stream().collect(Collectors.groupingBy(PackageData::getWaybillNumber));
// 根据运单号 统计 每个运单的数量
Map<String, Integer> waybillCountMap = new HashMap<>();
for (PackageData packageData : details) {
String waybillNumber = packageData.getWaybillNumber();
waybillCountMap.put(waybillNumber, waybillCountMap.getOrDefault(waybillNumber, 0) + packageData.getNumber());
}
Set<String> strings = waybillCountMap.keySet();
for (String waybillNumber : strings) {
WaybillLogDTO t = new WaybillLogDTO();
List<PackageData> packageDataList = map.get(waybillNumber);
if (packageDataList != null && !packageDataList.isEmpty()) {
packageDataList.sort(Comparator.comparing(PackageData::getSignTime));
// 获取排序第一个
t.setSignUser(packageDataList.get(0).getSignUser());
t.setSignTime(packageDataList.get(0).getSignTime());
}
t.setWaybillNo(waybillNumber);
t.setWarehouseName(bean.getWarehouse());
t.setWarehouseId(warehouseId);
t.setTrainNumber(vo.getPickupBatch());
t.setCarNumber(vo.getCarNumber());
t.setDriverName(vo.getDriverName());
t.setDeliveryTime(vo.getDeliveryTime());
t.setNum(waybillCountMap.get(waybillNumber));
t.setSignOrderCode(vo.getPickupBatch());
t.setType(3);
trunklineWaybillTrackClient.addSignWaybillLog(t);
}
}
/**
* 配送签收复核
* @param msg
*/
@RabbitListener(bindings = @QueueBinding(
value = @Queue(name = FanoutConstants.distribution.DeliveryAndrecheck.QUEUE.waybillStatusLog, durable = "true"),
exchange = @Exchange(name = FanoutConstants.distribution.DeliveryAndrecheck.EXCHANGE, type = ExchangeTypes.FANOUT)
))
@Transactional(rollbackFor = Exception.class)
public void statusDekiveryLog(String msg) {
log.info("商/市配送 复核处理运单日志和状态: {}", msg);
if (StrUtil.isEmpty(msg)) {
return;
}
NodeFanoutMsg bean = JSONUtil.toBean(msg, NodeFanoutMsg.class);
Object main = bean.getMain();
JSONObject entries = JSONUtil.parseObj(main);
DistributionReCheckSignVO vo = JSONUtil.toBean(entries, DistributionReCheckSignVO.class);
Long warehouseId = bean.getWarehouseId();
BizOperationEnums bizOperation = bean.getBizOperation();
List<PackageData> details = vo.getPackageDataList();
// 按照运单号进行分组 后面的集合 按照创建时间进行排序
Map<String, List<PackageData>> map = details.stream().collect(Collectors.groupingBy(PackageData::getWaybillNumber));
// 根据运单号 统计 每个运单的数量
Map<String, Integer> waybillCountMap = new HashMap<>();
for (PackageData packageData : details) {
String waybillNumber = packageData.getWaybillNumber();
waybillCountMap.put(waybillNumber, waybillCountMap.getOrDefault(waybillNumber, 0) + packageData.getNumber());
}
Set<String> strings = waybillCountMap.keySet();
for (String waybillNumber : strings) {
WaybillLogDTO t = new WaybillLogDTO();
List<PackageData> packageDataList = map.get(waybillNumber);
if (packageDataList != null && !packageDataList.isEmpty()) {
packageDataList.sort(Comparator.comparing(PackageData::getSignTime));
// 获取排序第一个
t.setSignUser(packageDataList.get(0).getSignUser());
t.setSignTime(packageDataList.get(0).getSignTime());
}
t.setWaybillNo(waybillNumber);
t.setWarehouseName(bean.getWarehouse());
t.setWarehouseId(warehouseId);
t.setTrainNumber(vo.getTrainNumber());
t.setCarNumber(vo.getVehicleName());
t.setDriverName(vo.getDriverName());
t.setDeliveryTime(vo.getDeliveryTime());
t.setNum(waybillCountMap.get(waybillNumber));
t.setSignOrderCode(vo.getReservationCode());
t.setType(3);
trunklineWaybillTrackClient.addSignWaybillLog(t);
}
}
}

19
blade-service/logpm-trunkline/src/main/java/com/logpm/trunkline/service/impl/TrunklineWaybillTrackServiceImpl.java

@ -4,6 +4,7 @@ import com.baomidou.mybatisplus.core.metadata.IPage;
import com.logpm.trunkline.dto.OpenOrderDTO;
import com.logpm.trunkline.dto.WaybillLogDTO;
import com.logpm.trunkline.entity.TrunklineWaybillTrackEntity;
import com.logpm.trunkline.mapper.TrunklineWaybillPackageMapper;
import com.logpm.trunkline.mapper.TrunklineWaybillTrackMapper;
import com.logpm.trunkline.service.IOpenOrderAsyncService;
import com.logpm.trunkline.service.ITrunklineWaybillOrderService;
@ -27,12 +28,13 @@ import java.util.Objects;
@Service
@AllArgsConstructor
public class TrunklineWaybillTrackServiceImpl extends BaseServiceImpl<TrunklineWaybillTrackMapper, TrunklineWaybillTrackEntity> implements ITrunklineWaybillTrackService {
private final IWarehouseWaybillClient warehouseWaybillClient;
private final IOpenOrderAsyncService openOrderAsyncService;
private final ITrunklineWaybillOrderService waybillOrderService;
private final ITrunklineWaybillPackageService trunklineWaybillPackageService;
private final TrunklineWaybillPackageMapper trunklineWaybillPackageMapper;
@Override
public List<TrunklineWaybillTrackEntity> findWaybillLog(Long waybillId, String trackType) {
return baseMapper.findWaybillLog(waybillId,trackType);
@ -59,6 +61,11 @@ public class TrunklineWaybillTrackServiceImpl extends BaseServiceImpl<TrunklineW
String nickName = waybillLogDTO.getNickName();
if(StringUtil.isNotBlank(waybillNo)){
Integer packageStatus = trunklineWaybillPackageMapper.findMaxPackageStatus(waybillNo);
log.info(">>>>",packageStatus+" **");
WarehouseWaybillEntity warehouseWaybillEntity = warehouseWaybillClient.findByWaybillNo(waybillNo);
if(Objects.isNull(warehouseWaybillEntity)){
log.warn("未找到运单信息 waybillNo:{}",waybillNo);
@ -78,6 +85,7 @@ public class TrunklineWaybillTrackServiceImpl extends BaseServiceImpl<TrunklineW
updateWaybill.setSignCheckUserName(nickName);
updateWaybill.setSignCheckTime(new Date());
warehouseWaybillClient.updateEntity(updateWaybill);
warehouseWaybillEntity.setSignNum(updateWaybill.getSignNum());
if(waybillType == 1){
//订制品运单
@ -87,12 +95,8 @@ public class TrunklineWaybillTrackServiceImpl extends BaseServiceImpl<TrunklineW
}else if(waybillType == 2){
//零担运单
addZeroWaybillTrackLog(waybillLogDTO,warehouseWaybillEntity);
}
}
} catch (Exception e) {
log.error("添加签收日志失败",e);
@ -134,7 +138,6 @@ public class TrunklineWaybillTrackServiceImpl extends BaseServiceImpl<TrunklineW
default:
typeStr = "未知签收";
}
if(type == 3){
//如果是配送签收需要补录配送装车记录
String operationRemark = warehouseName+" 配送装车"+num+"件,车次号:"+trainNumber+",司机:"+driverName+",车牌号:"+carNumber+",装车人"+ loadingUser+",配送时间"+ CommonUtil.dateToStringGeneral(deliveryTime);
@ -146,6 +149,7 @@ public class TrunklineWaybillTrackServiceImpl extends BaseServiceImpl<TrunklineW
openOrderAsyncService.saveLog(waybillId,waybillNo,"100",warehouseName+" "+typeStr,operationRemark,nickName,userId,warehouseId,warehouseName);
trunklineWaybillPackageService.updateWaybillStatus(warehouseWaybillEntity);
}
private void addPackageWaybillTrackLog(WaybillLogDTO waybillLogDTO,Long waybillId) {
@ -185,7 +189,6 @@ public class TrunklineWaybillTrackServiceImpl extends BaseServiceImpl<TrunklineW
default:
typeStr = "未知签收";
}
if(type == 3){
//如果是配送签收需要补录配送装车记录
String operationRemark = warehouseName+" 配送装车"+num+"件,车次号:"+trainNumber+",司机:"+driverName+",车牌号:"+carNumber+",装车人"+ loadingUser+",配送时间"+ CommonUtil.dateToStringGeneral(deliveryTime);

Loading…
Cancel
Save