Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
C
clx-performance
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
姜武杰
clx-performance
Commits
ee32a239
提交
ee32a239
authored
11月 06, 2023
作者:
liruixin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
违约结算单金额计算
上级
c86cad94
显示空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
29 行增加
和
3 行删除
+29
-3
BreakContractSettlementOwnerServiceImpl.java
...reakcontract/BreakContractSettlementOwnerServiceImpl.java
+29
-3
没有找到文件。
performance-web/src/main/java/com/clx/performance/service/impl/breakcontract/BreakContractSettlementOwnerServiceImpl.java
浏览文件 @
ee32a239
...
...
@@ -9,6 +9,7 @@ import com.clx.order.feign.OrderFeign;
import
com.clx.order.vo.feign.FeignOrderVO
;
import
com.clx.order.vo.pc.owner.OwnerQuotationDetailVO
;
import
com.clx.performance.dao.OrderChildDao
;
import
com.clx.performance.dao.OrderGoodsDao
;
import
com.clx.performance.dao.breakcontract.BreakContractOwnerRecordDao
;
import
com.clx.performance.dao.breakcontract.BreakContractOwnerRuleDao
;
import
com.clx.performance.dao.breakcontract.BreakContractSettlementLogDao
;
...
...
@@ -17,6 +18,7 @@ import com.clx.performance.dao.settle.SettlementPlatformAccountDao;
import
com.clx.performance.enums.*
;
import
com.clx.performance.extranal.order.QuotationService
;
import
com.clx.performance.model.OrderChild
;
import
com.clx.performance.model.OrderGoods
;
import
com.clx.performance.model.breakcontract.BreakContractOwnerRecord
;
import
com.clx.performance.model.breakcontract.BreakContractOwnerRule
;
import
com.clx.performance.model.breakcontract.BreakContractSettlementLog
;
...
...
@@ -80,6 +82,8 @@ public class BreakContractSettlementOwnerServiceImpl implements BreakContractSe
private
final
QuotationService
quotationService
;
private
final
BreakContractOwnerRecordService
breakContractOwnerRecordService
;
private
final
BreakContractOwnerRecordDao
breakContractOwnerRecordDao
;
private
final
OrderGoodsDao
orderGoodsDao
;
...
...
@@ -333,12 +337,24 @@ public class BreakContractSettlementOwnerServiceImpl implements BreakContractSe
OrderChildEnum
.
Status
.
UNSETTLE
.
getCode
()});
BigDecimal
figure
;
//总费用
//订单号查询货单
List
<
OrderGoods
>
orderGoods
=
orderGoodsDao
.
getOrderGoodsListByOrderNo
(
param
.
getOrderNo
());
if
(
CollectionUtils
.
isEmpty
(
orderGoods
)){
BigDecimal
totalFreight
=
param
.
getTransportWeight
().
multiply
(
param
.
getValidFreightPrice
());
figure
=
totalFreight
.
multiply
(
reduceRule
.
getBeforeRatio
()).
multiply
(
param
.
getWeight
())
.
divide
(
param
.
getTransportWeight
(),
2
,
BigDecimal
.
ROUND_HALF_UP
);
}
else
{
List
<
OrderChild
>
orderChilds
=
orderChildDao
.
listOrderChildByOrderNoAndStatus
(
param
.
getOrderNo
(),
statusList
);
if
(
CollectionUtils
.
isEmpty
(
orderChilds
)){
BigDecimal
totalFreight
=
param
.
getTransportWeight
().
multiply
(
param
.
getValidFreightPrice
());
figure
=
totalFreight
.
multiply
(
reduceRule
.
getBefore
Ratio
()).
multiply
(
param
.
getWeight
())
figure
=
totalFreight
.
multiply
(
reduceRule
.
getAfter
Ratio
()).
multiply
(
param
.
getWeight
())
.
divide
(
param
.
getTransportWeight
(),
2
,
BigDecimal
.
ROUND_HALF_UP
);
}
else
{
BigDecimal
deliveredWeight
=
BigDecimal
.
ZERO
;
//已拉运的重量
BigDecimal
deliveredFreight
=
BigDecimal
.
ZERO
;
//已拉运的费用
for
(
OrderChild
orderChild
:
orderChilds
){
...
...
@@ -357,7 +373,7 @@ public class BreakContractSettlementOwnerServiceImpl implements BreakContractSe
figure
=
totalFreight
.
multiply
(
reduceRule
.
getAfterRatio
()).
multiply
(
param
.
getWeight
())
.
divide
(
param
.
getTransportWeight
(),
2
,
BigDecimal
.
ROUND_HALF_UP
);
}
}
//组装参数 生成违约记录 违约计费 违约结算单
BreakContractOwnerRecordAddParam
ownerRecordAddParam
=
new
BreakContractOwnerRecordAddParam
();
...
...
@@ -425,12 +441,20 @@ public class BreakContractSettlementOwnerServiceImpl implements BreakContractSe
OrderChildEnum
.
Status
.
UNSETTLE
.
getCode
()});
BigDecimal
figure
;
//总费用
//订单号查询货单
List
<
OrderGoods
>
orderGoods
=
orderGoodsDao
.
getOrderGoodsListByOrderNo
(
orderNo
);
if
(
CollectionUtils
.
isEmpty
(
orderGoods
)){
figure
=
orderInfoFeign
.
getTransportWeight
().
multiply
(
orderInfoFeign
.
getValidFreightPrice
()).
multiply
(
orderCancelRule
.
getBeforeRatio
());
}
else
{
List
<
OrderChild
>
orderChilds
=
orderChildDao
.
listOrderChildByOrderNoAndStatus
(
orderNo
,
statusList
);
LocalDateTime
now
=
LocalDateTime
.
now
();
//当前时间
//没有司机拉运
if
(
CollectionUtils
.
isEmpty
(
orderChilds
)){
figure
=
orderInfoFeign
.
getTransportWeight
().
multiply
(
orderInfoFeign
.
getValidFreightPrice
()).
multiply
(
orderCancelRule
.
getBefore
Ratio
());
figure
=
orderInfoFeign
.
getTransportWeight
().
multiply
(
orderInfoFeign
.
getValidFreightPrice
()).
multiply
(
orderCancelRule
.
getAfter
Ratio
());
}
else
{
BigDecimal
deliveredWeight
=
BigDecimal
.
ZERO
;
//已拉运的重量
BigDecimal
cancelWeight
=
BigDecimal
.
ZERO
;
//可取消的重量
...
...
@@ -462,6 +486,8 @@ public class BreakContractSettlementOwnerServiceImpl implements BreakContractSe
.
divide
(
new
BigDecimal
(
60
),
2
,
BigDecimal
.
ROUND_HALF_UP
);
figure
=
baseFigure
.
add
(
truckFigure
);
}
}
//组装参数 生成违约记录 违约计费 违约结算单
BreakContractOwnerRecordAddParam
ownerRecordAddParam
=
new
BreakContractOwnerRecordAddParam
();
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论