From 0ab9dfd8f122195e4e9f09bd50c59e0a47450bec Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期三, 19 三月 2025 15:50:03 +0800
Subject: [PATCH] fix: resolve merge conflicts in .gitignore

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TBankFlowServiceImpl.java |  139 ++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 139 insertions(+), 0 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TBankFlowServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TBankFlowServiceImpl.java
new file mode 100644
index 0000000..147a3ea
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TBankFlowServiceImpl.java
@@ -0,0 +1,139 @@
+package com.ruoyi.system.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.basic.PageInfo;
+import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.system.importExcel.TBankFlowImportExcel;
+import com.ruoyi.system.mapper.TBankFlowMapper;
+import com.ruoyi.system.model.TBankFlow;
+import com.ruoyi.system.model.TBill;
+import com.ruoyi.system.model.TFlowManagement;
+import com.ruoyi.system.query.TBankFlowQuery;
+import com.ruoyi.system.query.TFlowManagementQuery;
+import com.ruoyi.system.service.TBankFlowService;
+import com.ruoyi.system.service.TFlowManagementService;
+import com.ruoyi.system.vo.TBankFlowStatisticsVo;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
+import java.time.format.DateTimeParseException;
+import java.util.List;
+
+/**
+ * <p>
+ * 流水管理 服务实现类
+ * </p>
+ *
+ * @author xiaochen
+ * @since 2025-02-07
+ */
+@Service
+public class TBankFlowServiceImpl extends ServiceImpl<TBankFlowMapper, TBankFlow> implements TBankFlowService {
+    @Autowired
+    TFlowManagementService flowManagementService;
+    @Override
+    public PageInfo<TBankFlow> pageList(TBankFlowQuery query) {
+        PageInfo<TBankFlow> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
+        LambdaQueryWrapper<TBankFlow> queryWrapper = new LambdaQueryWrapper<>();
+        queryWrapper.eq(StringUtils.isNotEmpty(query.getBankSerialNumber()),TBankFlow::getBankSerialNumber,query.getBankSerialNumber())
+                .like(StringUtils.isNotEmpty(query.getPayer()),TBankFlow::getPayer,query.getPayer())
+                .ge(StringUtils.isNotEmpty(query.getPayStartTime()),TBankFlow::getPayTime,query.getPayStartTime())
+                .lt(StringUtils.isNotEmpty(query.getPayEndTime()),TBankFlow::getPayTime,query.getPayEndTime())
+                .eq(null != query.getFlowStatus(),TBankFlow::getFlowStatus,query.getFlowStatus())
+                .orderByDesc(TBankFlow::getCreateTime);
+        return this.baseMapper.selectPage(pageInfo, queryWrapper);
+    }
+
+    @Override
+    public TBankFlowStatisticsVo getPaymentStats(TBankFlowQuery query) {
+        return this.baseMapper.getPaymentStats(query);
+    }
+
+    /**
+     * 根据银行流水号模糊查询
+     * @param bankSerialNumber
+     * @return
+     */
+    @Override
+    public List<TBankFlow> searchByBankSerialNumber(String bankSerialNumber) {
+        LambdaQueryWrapper<TBankFlow> queryWrapper = new LambdaQueryWrapper<>();
+        queryWrapper.like(StringUtils.isNotEmpty(bankSerialNumber),TBankFlow::getBankSerialNumber,bankSerialNumber)
+                .orderByDesc(TBankFlow::getPayTime);
+
+        PageInfo<TBankFlow> pageInfo = new PageInfo<>(1, 20);
+        pageInfo = this.baseMapper.selectPage(pageInfo, queryWrapper);
+        return pageInfo.getRecords();
+    }
+
+    @Override
+    public void saveImportBatch(List<TBankFlowImportExcel> list, List<TBankFlowImportExcel> failList) {
+        for (TBankFlowImportExcel row : list) {
+            try {
+                TBankFlow preexist = findUniq(row.getBankSerialNumber());
+                if (preexist != null){
+                    row.setResult("流水号已存在"+row.getBankSerialNumber());
+                    failList.add(row);
+                    continue;
+                }
+                TBankFlow flow = new TBankFlow();
+                BeanUtils.copyProperties(row,flow);
+                try {
+                    LocalDateTime parse = LocalDateTime.parse(row.getPayTime(), DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
+                    flow.setPayTime(parse);
+                }catch (DateTimeParseException e){
+                    row.setResult("支付时间格式不正确"+row.getPayTime());
+                    failList.add(row);
+                    continue;
+                }
+                TFlowManagementQuery query = new TFlowManagementQuery();
+                query.setBankSerialNumber(row.getBankSerialNumber());
+                List<TFlowManagement> list1 = flowManagementService.findByBankSerialNumber(row.getBankSerialNumber());
+                for (TFlowManagement tFlowManagement : list1) {
+                    // 如果相同流水号金额相同 :抵扣金额为流水金额,剩余金额为0,状态为正常
+                    if (row.getFlowMoney().compareTo(tFlowManagement.getFlowMoney()) == 0){
+                        flow.setDeductionMoney(tFlowManagement.getFlowMoney());
+                        flow.setRemainingMoney(BigDecimal.ZERO);
+                        flow.setFlowStatus(1);
+                        this.baseMapper.insert(flow);
+                        break;
+                    }else {
+                        // 流水号相同,金额不同:已抵扣金额为系统流水金额,剩余金额 = 银行流水金额-系统流水金额,状态为异常
+                        flow.setDeductionMoney(tFlowManagement.getFlowMoney());
+                        flow.setRemainingMoney(row.getFlowMoney().divide(tFlowManagement.getFlowMoney(),2, RoundingMode.HALF_DOWN));
+                        flow.setFlowStatus(2);
+                        this.baseMapper.insert(flow);
+                        break;
+                    }
+                }
+                // 系统流水查找不到:抵扣金额为0,剩余金额为流水金额,状态为异常
+                flow.setDeductionMoney(BigDecimal.ZERO);
+                flow.setRemainingMoney(row.getFlowMoney());
+                flow.setFlowStatus(2);
+                this.baseMapper.insert(flow);
+            }catch (Exception e){
+                log.error("导入银行流水信息异常",e);
+                row.setResult("导入异常:"+e.getMessage());
+                failList.add(row);
+            }
+        }
+    }
+
+    /**
+     * 根据流水号查找唯一流水
+     * @param bankSerialNumber
+     * @return
+     */
+
+    @Override
+    public TBankFlow findUniq(String bankSerialNumber) {
+        LambdaQueryWrapper<TBankFlow> queryWrapper = new LambdaQueryWrapper<>();
+        queryWrapper.eq(StringUtils.isNotEmpty(bankSerialNumber),TBankFlow::getBankSerialNumber,bankSerialNumber);
+        return this.baseMapper.selectOne(queryWrapper);
+    }
+}

--
Gitblit v1.7.1