|
|
@@ -5,25 +5,29 @@ import com.github.pagehelper.PageInfo;
|
|
|
import com.sckw.core.exception.BusinessException;
|
|
|
import com.sckw.core.model.page.PageRes;
|
|
|
import com.sckw.core.utils.IdWorker;
|
|
|
+import com.sckw.core.web.context.LoginUserHolder;
|
|
|
+import com.sckw.payment.api.model.constant.ChannelEnum;
|
|
|
+import com.sckw.payment.api.model.dto.WalletDto;
|
|
|
+import com.sckw.payment.api.model.dto.common.R;
|
|
|
import com.sckw.payment.dao.KwpSettlementLogisticsMapper;
|
|
|
-import com.sckw.payment.dao.KwpSettlementTradeMapper;
|
|
|
import com.sckw.payment.dao.KwpSettlementWalletMapper;
|
|
|
import com.sckw.payment.model.KwpSettlementLogistics;
|
|
|
import com.sckw.payment.model.KwpSettlementTrade;
|
|
|
+import com.sckw.payment.model.KwpSettlementTradeTrack;
|
|
|
import com.sckw.payment.model.KwpSettlementWallet;
|
|
|
-import com.sckw.payment.model.constant.SettlementEnum;
|
|
|
-import com.sckw.payment.model.constant.SettlementOrderTypeEnum;
|
|
|
-import com.sckw.payment.model.constant.SettlementWalletPayTypeEnum;
|
|
|
-import com.sckw.payment.model.constant.WalletChannelEnum;
|
|
|
+import com.sckw.payment.model.constant.*;
|
|
|
+import com.sckw.payment.model.dto.LedgerUnitDto;
|
|
|
import com.sckw.payment.model.dto.SettlementLogisticsDto;
|
|
|
import com.sckw.payment.model.dto.SettlementTradeDto;
|
|
|
import com.sckw.payment.model.dto.SettlementWalletDto;
|
|
|
import com.sckw.payment.model.vo.req.SettlementWalletReq;
|
|
|
+import com.sckw.payment.model.vo.req.WalletPayReq;
|
|
|
import com.sckw.payment.model.vo.res.SettlementWalletVo;
|
|
|
import com.sckw.system.api.RemoteSystemService;
|
|
|
import com.sckw.system.api.model.dto.res.UserCacheResDto;
|
|
|
import jakarta.annotation.Resource;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
+import org.apache.commons.lang3.StringUtils;
|
|
|
import org.apache.dubbo.config.annotation.DubboReference;
|
|
|
import org.springframework.beans.BeanUtils;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
@@ -54,9 +58,11 @@ public class KwpSettlementWalletService {
|
|
|
@Resource
|
|
|
private KwpSettlementTradeService kwpSettlementTradeService;
|
|
|
@Resource
|
|
|
- private KwpSettlementTradeMapper kwpSettlementTradeMapper;
|
|
|
+ private PayCenterService payCenterService;
|
|
|
@Resource
|
|
|
- private KwpLedgerTradeService ledgerTradeService;
|
|
|
+ private KwpWalletRelationService walletRelationService;
|
|
|
+ @Resource
|
|
|
+ private KwpSettlementTradeTrackService settlementTradeTrackService;
|
|
|
@DubboReference(version = "2.0.0", group = "design", check = false)
|
|
|
private RemoteSystemService remoteSystemService;
|
|
|
|
|
|
@@ -162,7 +168,7 @@ public class KwpSettlementWalletService {
|
|
|
kwpSettlementWallet.setEntId(settlementLogisticsDto.getEntId());
|
|
|
kwpSettlementWallet.setSettlementId(settlementLogisticsDto.getId());
|
|
|
kwpSettlementWallet.setOrderType(SettlementOrderTypeEnum.LOGISTICS.getStatus());
|
|
|
- kwpSettlementWallet.setChannel(WalletChannelEnum.HF.getStatus());//先用数字默认定义为1
|
|
|
+ kwpSettlementWallet.setChannel(WalletChannelEnum.HF.getValue());//先用数字默认定义为1
|
|
|
kwpSettlementWallet.setPayTime(LocalDateTime.now());
|
|
|
kwpSettlementWallet.setPayPrice(price);
|
|
|
kwpSettlementWallet.setTopayPrice(remainingReceivables);
|
|
|
@@ -214,74 +220,94 @@ public class KwpSettlementWalletService {
|
|
|
|
|
|
|
|
|
/**
|
|
|
- * 销售-付款确认-(新增电子钱包记录-采购货到付款)
|
|
|
+ * 销售-付款确认-货到付款
|
|
|
*
|
|
|
* @author Aick Spt
|
|
|
* @date 2023-07-27 16:13
|
|
|
*/
|
|
|
- public Integer confirmTradePayment(Long id, BigDecimal price) {
|
|
|
- //先查询出结算单情况
|
|
|
- SettlementTradeDto settlementTradeDto = kwpSettlementTradeService.detailPayment(id);
|
|
|
- log.info(String.valueOf(settlementTradeDto));
|
|
|
- //检查结算单状态和所差金额
|
|
|
- if (settlementTradeDto == null) {
|
|
|
- log.error("非法请求,查无数据:" + id);
|
|
|
- throw new BusinessException("非法请求运费结算参数ID");
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public String confirmTradePayment(WalletPayReq walletPayReq) {
|
|
|
+ SettlementTradeDto byId = kwpSettlementTradeService.getById(walletPayReq.getIdLong(), TradeUnitType.SELL);
|
|
|
+ if (Objects.isNull(byId)) {
|
|
|
+ throw new BusinessException("结算单不存在");
|
|
|
}
|
|
|
- if (settlementTradeDto.getStatus() == SettlementEnum.ALL_PAYMENT.getStatus()) {
|
|
|
- log.error("非法请求,该订单已结算完成:" + id);
|
|
|
- throw new BusinessException("该订单已结算完成,无法操作");
|
|
|
+ if (StringUtils.isNotBlank(byId.getTrading()) && !byId.getTrading().startsWith(TradingEnum.RECEIVE_PAY.getValue())) {
|
|
|
+ throw new BusinessException("只支持货货到付款方式订单进行当前操作");
|
|
|
+ }
|
|
|
+ List<LedgerUnitDto> listById = kwpSettlementTradeService.getListById(walletPayReq.getIdLong());
|
|
|
+ if (CollectionUtils.isEmpty(listById) || listById.size() != 2) {
|
|
|
+ throw new BusinessException("对账单交易企业双方不存在或缺少");
|
|
|
+ }
|
|
|
+ Long uid = null;
|
|
|
+ Long filter = null;
|
|
|
+ for (LedgerUnitDto ledgerUnitDto : listById) {
|
|
|
+ Integer unitType = ledgerUnitDto.getUnitType();
|
|
|
+ if (TradeUnitType.PURCHASE.equals(unitType)) {
|
|
|
+ uid = ledgerUnitDto.getTopEntId();
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ if (TradeUnitType.SELL.equals(unitType)) {
|
|
|
+ filter = ledgerUnitDto.getTopEntId();
|
|
|
+ }
|
|
|
}
|
|
|
- BigDecimal remainingReceivables = settlementTradeDto.getTotalPrice();
|
|
|
- if (settlementTradeDto.getActualPrice() != null) {//剩余金额
|
|
|
- remainingReceivables = settlementTradeDto.getTotalPrice().subtract(settlementTradeDto.getActualPrice());
|
|
|
+ String relation = walletRelationService.getRelation(uid);
|
|
|
+ String filterUser = walletRelationService.getRelation(filter);
|
|
|
+ if (StringUtils.isBlank(relation) || StringUtils.isBlank(filterUser)) {
|
|
|
+ throw new BusinessException("顶级企业未开通电子钱包");
|
|
|
}
|
|
|
+ //付款金额
|
|
|
+ BigDecimal price = walletPayReq.getPrice();
|
|
|
+ //todo-xcq-完善
|
|
|
|
|
|
- if (remainingReceivables.compareTo(price) < 0) {//-1表示小于,0是等于,1是大于
|
|
|
- log.error("本次结算输入金额比剩余付款金额大:ID:" + id + " 剩余金额:" + remainingReceivables + " 本次输入金额:" + price);
|
|
|
- throw new BusinessException("参数错误:输入金额过大 " + price + " 剩余金额最大值:" + remainingReceivables);
|
|
|
+// R<List<WalletDto>> wallet = payCenterService.wallet(relation, ChannelEnum.getByCode(byId.getTrading()), filterUser);
|
|
|
+// if (CollectionUtils.isEmpty(wallet.getData())) {
|
|
|
+// throw new BusinessException("暂未开通电子钱包");
|
|
|
+// }
|
|
|
+// List<WalletDto> data = wallet.getData();
|
|
|
+// BigDecimal bigDecimal = BigDecimal.valueOf(data.get(0).getMoney()).divide(new BigDecimal("100.0"), RoundingMode.UNNECESSARY);
|
|
|
+//
|
|
|
+// if (bigDecimal.compareTo(price) < 0) {
|
|
|
+// throw new BusinessException("钱包可用余额不足");
|
|
|
+// }
|
|
|
+ //待付款金额-本次付款金额= 剩余待付款金额
|
|
|
+ BigDecimal subtract = byId.getWaitPrice().subtract(walletPayReq.getPrice());
|
|
|
+ if (subtract.compareTo(new BigDecimal("0.0")) < 0) {
|
|
|
+ throw new BusinessException("付款金额不能大于待付款金额");
|
|
|
}
|
|
|
- //累加入库结算单
|
|
|
+ //新增电子钱包结算记录
|
|
|
+ KwpSettlementWallet kwpSettlementWallet = new KwpSettlementWallet();
|
|
|
+ kwpSettlementWallet.setId(new IdWorker(1).nextId());
|
|
|
+ kwpSettlementWallet.setEntId(LoginUserHolder.getEntId());
|
|
|
+ kwpSettlementWallet.setSettlementId(walletPayReq.getIdLong());
|
|
|
+ kwpSettlementWallet.setOrderType(SettlementOrderTypeEnum.TRADE.getStatus());
|
|
|
+ kwpSettlementWallet.setChannel(WalletChannelEnum.getValue(byId.getTrading()));
|
|
|
+ kwpSettlementWallet.setPayTime(LocalDateTime.now());
|
|
|
+ kwpSettlementWallet.setPayPrice(walletPayReq.getPrice());
|
|
|
+ kwpSettlementWallet.setTopayPrice(subtract);
|
|
|
+ kwpSettlementWallet.setType(SettlementWalletPayTypeEnum.CASH_ON_DELIVERY.getStatus());
|
|
|
+ kwpSettlementWallet.setRemark("");
|
|
|
+ kwpSettlementWallet.setStatus(0);
|
|
|
+ kwpSettlementWallet.setCreateBy(LoginUserHolder.getUserId());
|
|
|
+ kwpSettlementWallet.setCreateTime(LocalDateTime.now());
|
|
|
+ kwpSettlementWallet.setUpdateBy(LoginUserHolder.getUserId());
|
|
|
+ kwpSettlementWallet.setUpdateTime(LocalDateTime.now());
|
|
|
+ kwpSettlementWallet.setDelFlag(0);
|
|
|
+ settlementWalletMapper.insert(kwpSettlementWallet);
|
|
|
+
|
|
|
+ //更新交易结算单状态和金额
|
|
|
KwpSettlementTrade kwpSettlementTrade = new KwpSettlementTrade();
|
|
|
- kwpSettlementTrade.setId(settlementTradeDto.getId());
|
|
|
+ kwpSettlementTrade.setId(byId.getId());
|
|
|
+ kwpSettlementTrade.setActualPrice(byId.getActualPrice().add(price));
|
|
|
+ kwpSettlementTrade.setStatus(subtract.compareTo(new BigDecimal("0.0")) == 0 ? SettlementEnum.ALL_PAYMENT.getStatus()
|
|
|
+ : SettlementEnum.PARTIAL_PAYMENT.getStatus());
|
|
|
+ kwpSettlementTrade.setUpdateBy(LoginUserHolder.getUserId());
|
|
|
kwpSettlementTrade.setUpdateTime(LocalDateTime.now());
|
|
|
- if (remainingReceivables.compareTo(price) == 0) {//全部结算
|
|
|
- kwpSettlementTrade.setStatus(SettlementEnum.ALL_PAYMENT.getStatus());
|
|
|
- }
|
|
|
- if (remainingReceivables.compareTo(price) > 0) {//部分结算
|
|
|
- kwpSettlementTrade.setStatus(SettlementEnum.PARTIAL_PAYMENT.getStatus());
|
|
|
- }
|
|
|
- BigDecimal actualPrice = settlementTradeDto.getActualPrice();
|
|
|
- kwpSettlementTrade.setActualPrice((actualPrice == null) ? price : actualPrice.add(price));
|
|
|
- int upInt = kwpSettlementTradeMapper.updateById(kwpSettlementTrade);
|
|
|
- if (upInt > 0) {
|
|
|
- //新增一条电子钱包结算记录
|
|
|
- remainingReceivables = remainingReceivables.subtract(price);
|
|
|
- KwpSettlementWallet kwpSettlementWallet = new KwpSettlementWallet();
|
|
|
- kwpSettlementWallet.setId(new IdWorker(1).nextId());
|
|
|
- kwpSettlementWallet.setEntId(settlementTradeDto.getEntId());
|
|
|
- kwpSettlementWallet.setSettlementId(settlementTradeDto.getId());
|
|
|
- kwpSettlementWallet.setOrderType(SettlementOrderTypeEnum.LOGISTICS.getStatus());
|
|
|
- kwpSettlementWallet.setChannel(WalletChannelEnum.HF.getStatus());//先用数字默认定义为1
|
|
|
- kwpSettlementWallet.setPayTime(LocalDateTime.now());
|
|
|
- kwpSettlementWallet.setPayPrice(price);
|
|
|
- kwpSettlementWallet.setTopayPrice(remainingReceivables);
|
|
|
- kwpSettlementWallet.setType(SettlementWalletPayTypeEnum.CASH_ON_DELIVERY.getStatus());
|
|
|
- kwpSettlementWallet.setRemark("");
|
|
|
- kwpSettlementWallet.setStatus(1);
|
|
|
- kwpSettlementWallet.setCreateBy(1L);//todo 待处理明确创建人
|
|
|
- kwpSettlementWallet.setCreateTime(LocalDateTime.now());
|
|
|
- kwpSettlementWallet.setUpdateBy(1L);//todo 待处理明确更新人
|
|
|
- kwpSettlementWallet.setUpdateTime(LocalDateTime.now());
|
|
|
- kwpSettlementWallet.setDelFlag(0);
|
|
|
- Integer insertKwpSettlementWallet = settlementWalletMapper.insert(kwpSettlementWallet);
|
|
|
+ kwpSettlementTradeService.updateById(kwpSettlementTrade);
|
|
|
|
|
|
- //物流货到付款电子钱包逻辑
|
|
|
- //todo 待处理费电子钱包逻辑
|
|
|
+ settlementTradeTrackService.save(KwpSettlementTradeTrack.build(byId.getId(), SettlementTrackEnum.RECEIVE_PAY.getStatus()));
|
|
|
+ //todo-xcq 调用中台接口
|
|
|
|
|
|
- return insertKwpSettlementWallet;
|
|
|
- }
|
|
|
- return null;
|
|
|
+ return "付款确认成功";
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
@@ -355,26 +381,94 @@ public class KwpSettlementWalletService {
|
|
|
return new PageRes<>(new PageInfo<>(collect));
|
|
|
}
|
|
|
|
|
|
-
|
|
|
- public Integer confirmTradeCollection(Long id, Float price) {
|
|
|
- log.info("接收到数据,开始物流-销售-收款确认-预付款(电子钱包)-新增,待完善");
|
|
|
- //todo 待完善
|
|
|
- //先查询出结算单情况
|
|
|
-
|
|
|
- //检查结算单状态和所差金额
|
|
|
-
|
|
|
- //对比金额
|
|
|
-
|
|
|
- //累加入库结算单
|
|
|
-
|
|
|
- //扣费电子钱包
|
|
|
-
|
|
|
+ /**
|
|
|
+ * 销售-预付款
|
|
|
+ *
|
|
|
+ * @param id
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public String confirmTradeCollection(Long id) {
|
|
|
+ SettlementTradeDto byId = kwpSettlementTradeService.getById(id, TradeUnitType.PURCHASE);
|
|
|
+ if (Objects.isNull(byId)) {
|
|
|
+ throw new BusinessException("结算单不存在");
|
|
|
+ }
|
|
|
+ if (StringUtils.isNotBlank(byId.getTrading()) && !byId.getTrading().startsWith(TradingEnum.PRE_PAY.getValue())) {
|
|
|
+ throw new BusinessException("只支持预付款交易方法进行预付款确认操作");
|
|
|
+ }
|
|
|
+ //更新交易结算单状态和金额
|
|
|
+ KwpSettlementTrade kwpSettlementTrade = new KwpSettlementTrade();
|
|
|
+ kwpSettlementTrade.setId(byId.getId());
|
|
|
+ kwpSettlementTrade.setActualPrice(byId.getTotalPrice());
|
|
|
+ kwpSettlementTrade.setStatus(SettlementEnum.ALL_PAYMENT.getStatus());
|
|
|
+ kwpSettlementTrade.setUpdateBy(LoginUserHolder.getUserId());
|
|
|
+ kwpSettlementTrade.setUpdateTime(LocalDateTime.now());
|
|
|
+ kwpSettlementTradeService.updateById(kwpSettlementTrade);
|
|
|
//新增电子钱包结算记录
|
|
|
KwpSettlementWallet kwpSettlementWallet = new KwpSettlementWallet();
|
|
|
kwpSettlementWallet.setId(new IdWorker(1).nextId());
|
|
|
- //todo 待完善
|
|
|
+ kwpSettlementWallet.setEntId(LoginUserHolder.getEntId());
|
|
|
+ kwpSettlementWallet.setSettlementId(byId.getId());
|
|
|
+ kwpSettlementWallet.setOrderType(SettlementOrderTypeEnum.TRADE.getStatus());
|
|
|
+ kwpSettlementWallet.setChannel(WalletChannelEnum.getValue(byId.getTrading()));
|
|
|
+ kwpSettlementWallet.setPayTime(LocalDateTime.now());
|
|
|
+ kwpSettlementWallet.setPayPrice(byId.getTotalPrice());
|
|
|
+ kwpSettlementWallet.setTopayPrice(new BigDecimal("0.0"));
|
|
|
+ kwpSettlementWallet.setType(SettlementWalletPayTypeEnum.ADVANCE_PAYMENT.getStatus());
|
|
|
+ kwpSettlementWallet.setRemark("");
|
|
|
+ kwpSettlementWallet.setStatus(0);
|
|
|
+ kwpSettlementWallet.setCreateBy(LoginUserHolder.getUserId());
|
|
|
+ kwpSettlementWallet.setCreateTime(LocalDateTime.now());
|
|
|
+ kwpSettlementWallet.setUpdateBy(LoginUserHolder.getUserId());
|
|
|
+ kwpSettlementWallet.setUpdateTime(LocalDateTime.now());
|
|
|
+ kwpSettlementWallet.setDelFlag(0);
|
|
|
settlementWalletMapper.insert(kwpSettlementWallet);
|
|
|
- return settlementWalletMapper.confirmLogisticsPayment(id, price);
|
|
|
+ settlementTradeTrackService.save(KwpSettlementTradeTrack.build(byId.getId(), SettlementTrackEnum.PRE_PAY.getStatus()));
|
|
|
+ //todo-xcq 调用中台接口
|
|
|
+ //todo-xcq 调用订单接口,更新订单状态
|
|
|
+ return "确认回款成功";
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 电子钱包余额
|
|
|
+ *
|
|
|
+ * @param id
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public BigDecimal getConfirmTradePayment(Long id) {
|
|
|
+ SettlementTradeDto byId = kwpSettlementTradeService.getById(id, TradeUnitType.SELL);
|
|
|
+ if (Objects.isNull(byId)) {
|
|
|
+ throw new BusinessException("结算单不存在");
|
|
|
+ }
|
|
|
+ if (StringUtils.isNotBlank(byId.getTrading()) && !byId.getTrading().startsWith(TradingEnum.RECEIVE_PAY.getValue())) {
|
|
|
+ throw new BusinessException("只支持货货到付款方式订单进行当前操作");
|
|
|
+ }
|
|
|
+ List<LedgerUnitDto> listById = kwpSettlementTradeService.getListById(id);
|
|
|
+ if (CollectionUtils.isEmpty(listById) || listById.size() != 2) {
|
|
|
+ throw new BusinessException("对账单交易企业双方不存在或缺少");
|
|
|
+ }
|
|
|
+ Long uid = null;
|
|
|
+ Long filter = null;
|
|
|
+ for (LedgerUnitDto ledgerUnitDto : listById) {
|
|
|
+ Integer unitType = ledgerUnitDto.getUnitType();
|
|
|
+ if (TradeUnitType.PURCHASE.equals(unitType)) {
|
|
|
+ uid = ledgerUnitDto.getTopEntId();
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ if (TradeUnitType.SELL.equals(unitType)) {
|
|
|
+ filter = ledgerUnitDto.getTopEntId();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ String relation = walletRelationService.getRelation(uid);
|
|
|
+ String filterUser = walletRelationService.getRelation(filter);
|
|
|
+ if (StringUtils.isBlank(relation) || StringUtils.isBlank(filterUser)) {
|
|
|
+ throw new BusinessException("顶级企业未开通电子钱包");
|
|
|
+ }
|
|
|
+ R<List<WalletDto>> wallet = payCenterService.wallet(relation, ChannelEnum.getByCode(byId.getTrading()), filterUser);
|
|
|
+ if (CollectionUtils.isEmpty(wallet.getData())) {
|
|
|
+ throw new BusinessException("暂未开通电子钱包");
|
|
|
+ }
|
|
|
+ List<WalletDto> data = wallet.getData();
|
|
|
+ return BigDecimal.valueOf(data.get(0).getMoney() / 100.0);
|
|
|
}
|
|
|
}
|
|
|
|