Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
C
clx-performance
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
姜武杰
clx-performance
Commits
152005dd
提交
152005dd
authored
12月 18, 2023
作者:
huyufan
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'origin/v6.5_transport_open_20231115' into test
上级
db547244
03e92e84
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
44 行增加
和
15 行删除
+44
-15
SettlementOwnerServiceImpl.java
...mance/service/impl/settle/SettlementOwnerServiceImpl.java
+1
-0
SettlementServiceImpl.java
...erformance/service/impl/settle/SettlementServiceImpl.java
+43
-15
没有找到文件。
performance-web/src/main/java/com/clx/performance/service/impl/settle/SettlementOwnerServiceImpl.java
浏览文件 @
152005dd
...
...
@@ -534,6 +534,7 @@ public class SettlementOwnerServiceImpl implements SettlementOwnerService {
SettlementOwnerEnum
.
InvoiceType
.
ONLINE
.
getCode
(),
SettlementOwnerEnum
.
InvoiceStatus
.
NOT_INVOICE
.
getCode
());
if
(
CollectionUtil
.
isEmpty
(
list
))
{
log
.
info
(
"开票结果回调查询当前结算单均已开完票,结算单信息为{}"
,
settlementNo
);
return
;
}
settlementOwnerDetailDao
.
updateSettlementByChildNoList
(
childNoList
);
...
...
performance-web/src/main/java/com/clx/performance/service/impl/settle/SettlementServiceImpl.java
浏览文件 @
152005dd
...
...
@@ -77,9 +77,11 @@ public class SettlementServiceImpl implements SettlementService {
SettlementOwnerDetail
settlementOwnerDetail
=
settlementOwnerDetailDao
.
getByChildNo
(
childNo
).
orElseThrow
(
PerformanceResultEnum
.
DATA_NOT_FIND
);
SettlementDriverDetail
settlementDriverDetail
=
settlementDriverDetailDao
.
getByChildNo
(
childNo
).
orElseThrow
(
PerformanceResultEnum
.
DATA_NOT_FIND
);
if
(
settlementOwnerDetail
.
getInvoiceType
()
!=
null
)
{
return
;}
if
(
settlementOwnerDetail
.
getInvoiceType
()
!=
null
)
{
return
;
}
// 开票金额
settlementOwnerDetail
.
setInvoiceFreight
(
invoiceFreightCalc
(
orderChild
.
getSettlementWay
(),
settlementOwnerDetail
));
settlementOwnerDetail
.
setInvoiceFreight
(
invoiceFreightCalc
(
orderChild
.
getSettlementWay
(),
settlementOwnerDetail
));
if
(
settlementDriverDetail
.
getSettlementFreight
().
compareTo
(
BigDecimal
.
ZERO
)
<
0
)
{
invoiceType
=
SettlementOwnerEnum
.
InvoiceType
.
ORDINARY
.
getCode
();
settlementDriverDetail
.
setPrepayFreightFlag
(
0
);
...
...
@@ -94,7 +96,7 @@ public class SettlementServiceImpl implements SettlementService {
log
.
info
(
"OrderChildSyncDTO信息为:{}"
,
JSONUtil
.
parse
(
bean
));
if
(
bean
.
getCode
()
==
0
)
{
Integer
status
=
bean
.
getData
().
getStatus
();
BigDecimal
ans
=
settlementOwnerDetail
.
getFreight
().
subtract
(
settlementOwnerDetail
.
getLossFreight
());
if
(
status
==
1
)
{
//通过风控
List
<
OwnerRunningWaterRecord
>
runningWaterRecordList
=
ownerRunningWaterRecordDao
.
getOwnerRunningWaterRecord
(
orderChild
.
getOrderNo
());
...
...
@@ -109,11 +111,14 @@ public class SettlementServiceImpl implements SettlementService {
&&
item
.
getAccountType
().
equals
(
OwnerAccountEnum
.
AccountTypeStatus
.
PREPAID_FREIGHT_ACCOUNT
.
getCode
())
;
}).
map
(
OwnerRunningWaterRecord:
:
getAlterationBalance
).
reduce
(
BigDecimal
.
ZERO
,
BigDecimal:
:
add
);
//设置预付运费金额
BigDecimal
ans
=
getPrepayFreightPay
(
orderChild
.
getSettlementWay
(),
settlementOwnerDetail
,
frozen
);
BigDecimal
subtract
=
frozen
.
subtract
(
takeOut
);
log
.
info
(
"冻结预付运费:{}, 扣除的流水总和:{}"
,
frozen
,
takeOut
);
invoiceType
=
SettlementOwnerEnum
.
InvoiceType
.
ONLINE
.
getCode
();
if
(
subtract
.
compareTo
(
BigDecimal
.
ZERO
)
<=
0
)
{
//此刻预付运费也可能为0,那么就不用生成扣除相关流水逻辑
if
(
subtract
.
compareTo
(
BigDecimal
.
ZERO
)
<=
0
||
ans
.
compareTo
(
BigDecimal
.
ZERO
)
==
0
)
{
settlementOwnerDetail
.
setPrepayFreight
(
BigDecimal
.
ZERO
);
settlementDriverDetail
.
setPrepayFreightFlag
(
0
);
...
...
@@ -129,7 +134,7 @@ public class SettlementServiceImpl implements SettlementService {
update
.
setModifiedTime
(
account
.
getModifiedTime
());
update
.
setFrozenBalance
(
ans
);
Integer
i
=
ownerAccountDao
.
updateOwnerAccountForConfirm
(
update
);
if
(
null
!=
i
&&
i
>
0
)
{
if
(
null
!=
i
&&
i
>
0
)
{
break
;
}
}
...
...
@@ -163,6 +168,8 @@ public class SettlementServiceImpl implements SettlementService {
}
else
{
settlementOwnerDetail
.
setPrepayFreight
(
BigDecimal
.
ZERO
);
settlementDriverDetail
.
setPrepayFreightFlag
(
0
);
}
}
...
...
@@ -178,7 +185,7 @@ public class SettlementServiceImpl implements SettlementService {
}
// 结算金额
settlementOwnerDetail
.
setSettlementFreight
(
settlementFreightCalc
(
orderChild
.
getSettlementWay
(),
settlementOwnerDetail
));
settlementOwnerDetail
.
setSettlementFreight
(
settlementFreightCalc
(
orderChild
.
getSettlementWay
(),
settlementOwnerDetail
));
if
(
SettlementOwnerEnum
.
InvoiceType
.
ORDINARY
.
getCode
().
equals
(
invoiceType
))
{
if
(
settlementOwnerDetail
.
getSettlementFreight
().
compareTo
(
BigDecimal
.
ZERO
)
==
0
)
{
settlementOwnerDetail
.
setFinalPaymentStatus
(
SettlementOwnerDetailEnum
.
FinalPaymentStatus
.
NO_REQUIRE
.
getCode
());
...
...
@@ -203,27 +210,47 @@ public class SettlementServiceImpl implements SettlementService {
/**
* 预付运费支付
*/
private
BigDecimal
updatePrepayFreightPay
(
String
childNo
,
BigDecimal
freight
,
BigDecimal
lossFreight
){
private
BigDecimal
updatePrepayFreightPay
(
String
childNo
,
BigDecimal
freight
,
BigDecimal
lossFreight
)
{
//开票金额
BigDecimal
prepayFreight
=
freight
.
subtract
(
lossFreight
);
if
(
prepayFreight
.
compareTo
(
BigDecimal
.
ZERO
)
<=
0
)
{
return
BigDecimal
.
ZERO
;}
if
(
prepayFreight
.
compareTo
(
BigDecimal
.
ZERO
)
<=
0
)
{
return
BigDecimal
.
ZERO
;
}
//扣减预付运费
return
prepayFreight
;
}
private
BigDecimal
getPrepayFreightPay
(
Integer
settlementWay
,
SettlementOwnerDetail
settlementOwnerDetail
,
BigDecimal
accountFrozenPrefreght
)
{
//订单结算方式为“装车净重”时
if
(
Objects
.
equals
(
settlementWay
,
SettlementWayEnum
.
WayType
.
LOAD
.
getCode
()))
{
BigDecimal
subtract
=
settlementOwnerDetail
.
getFreight
().
subtract
(
settlementOwnerDetail
.
getLossFreight
());
if
(
accountFrozenPrefreght
.
compareTo
(
subtract
)
>=
0
)
{
return
subtract
;
}
else
{
return
BigDecimal
.
ZERO
;
}
}
else
{
if
(
accountFrozenPrefreght
.
compareTo
(
settlementOwnerDetail
.
getFreight
())
==
0
)
{
return
settlementOwnerDetail
.
getFreight
();
}
else
{
return
BigDecimal
.
ZERO
;
}
}
}
/**
* 开票金额
*/
private
BigDecimal
invoiceFreightCalc
(
Integer
settlementWay
,
SettlementOwnerDetail
settlementOwnerDetail
)
{
if
(
Objects
.
equals
(
settlementWay
,
SettlementWayEnum
.
WayType
.
LOAD
.
getCode
()))
{
//订单结算方式为“装车净重”时,开票金额=实际净重*平台运费报价-货损金额。
private
BigDecimal
invoiceFreightCalc
(
Integer
settlementWay
,
SettlementOwnerDetail
settlementOwnerDetail
)
{
if
(
Objects
.
equals
(
settlementWay
,
SettlementWayEnum
.
WayType
.
LOAD
.
getCode
()))
{
//订单结算方式为“装车净重”时,开票金额=实际净重*平台运费报价-货损金额。
return
settlementOwnerDetail
.
getWeight
().
multiply
(
settlementOwnerDetail
.
getFreightPrice
())
.
subtract
(
settlementOwnerDetail
.
getLossFreight
());
}
else
{
//订单结算方式为“卸车净重”时,开票金额=实际净重*平台运费报价。
}
else
{
//订单结算方式为“卸车净重”时,开票金额=实际净重*平台运费报价。
return
settlementOwnerDetail
.
getWeight
().
multiply
(
settlementOwnerDetail
.
getFreightPrice
());
}
}
...
...
@@ -231,12 +258,13 @@ public class SettlementServiceImpl implements SettlementService {
/**
* 结算金额
*/
private
BigDecimal
settlementFreightCalc
(
Integer
settlementWay
,
SettlementOwnerDetail
settlementOwnerDetail
)
{
if
(
Objects
.
equals
(
settlementWay
,
SettlementWayEnum
.
WayType
.
LOAD
.
getCode
()))
{
//订单结算方式为“装车净重”时,结算金额=实际净重*平台运费报价-预付运费-货损金额。
private
BigDecimal
settlementFreightCalc
(
Integer
settlementWay
,
SettlementOwnerDetail
settlementOwnerDetail
)
{
if
(
Objects
.
equals
(
settlementWay
,
SettlementWayEnum
.
WayType
.
LOAD
.
getCode
()))
{
//订单结算方式为“装车净重”时,结算金额=实际净重*平台运费报价-预付运费-货损金额。
return
settlementOwnerDetail
.
getWeight
().
multiply
(
settlementOwnerDetail
.
getFreightPrice
())
.
subtract
(
settlementOwnerDetail
.
getPrepayFreight
()).
subtract
(
settlementOwnerDetail
.
getLossFreight
());
}
else
{
//订单结算方式为“卸车净重”时,结算金额=实际净重*平台运费报价-预付运费
}
else
{
//订单结算方式为“卸车净重”时,结算金额=实际净重*平台运费报价-预付运费
return
settlementOwnerDetail
.
getWeight
().
multiply
(
settlementOwnerDetail
.
getFreightPrice
()).
subtract
(
settlementOwnerDetail
.
getPrepayFreight
());
}
}
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论