From c0d52001041cd7806cac800611489172b335e4b0 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期二, 23 一月 2024 16:35:20 +0800
Subject: [PATCH] 代码提交

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceFundController.java |  184 ++++++++++++++++++++++++++++++++++++----------
 1 files changed, 144 insertions(+), 40 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceFundController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceFundController.java
index 0e26b67..c65212d 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceFundController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceFundController.java
@@ -1,8 +1,10 @@
 package com.ruoyi.web.controller.project;
 
 import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.ruoyi.common.annotation.Log;
+import com.ruoyi.common.annotation.NotRepeatCommit;
 import com.ruoyi.common.annotation.RepeatSubmit;
 import com.ruoyi.common.config.RuoYiConfig;
 import com.ruoyi.common.constant.HttpStatus;
@@ -13,6 +15,7 @@
 import com.ruoyi.common.core.page.TableDataInfo;
 import com.ruoyi.common.enums.BusinessType;
 import com.ruoyi.common.exception.ServiceException;
+import com.ruoyi.common.exception.base.BaseException;
 import com.ruoyi.common.tax.TaxtUtils;
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.StringUtils;
@@ -42,6 +45,7 @@
 import java.io.*;
 import java.math.BigDecimal;
 import java.text.SimpleDateFormat;
+import java.time.LocalDate;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -143,6 +147,9 @@
         Integer checkstatus = spFinancialExpensesIn.getCheckstatus();
 
         String donorname = spFinancialExpensesIn.getDonorname();
+        if (StringUtils.isEmpty(donorname)) {
+            donorname = null;
+        }
         if (pageNum == null) {
             pageNum = 1;
         }
@@ -475,6 +482,7 @@
      * 瀹℃牳璐圭敤
      */
     @ApiOperation("瀹℃牳璐圭敤")
+    @RepeatSubmit
 //    @Log(title = "瀹℃牳璐圭敤", businessType = BusinessType.OTHER)
     @PostMapping("/checkfund")
     public AjaxResult checkFund(@RequestBody CheckFundVO checkFundVO) {
@@ -488,7 +496,6 @@
             serviceFundflowrule.setApplytype(serviceFund.getApplytype());
             serviceFundflowrule.setCheckuserno(loginUser.getUsername());
             log.info("serviceFundController---checkFund---queryList鐨勫叆鍙傚�約erviceFundflowrule:{}", serviceFundflowrule);
-
             List<ServiceFundflowrule> serviceFundflowrules = serviceFundflowruleService.queryList(serviceFundflowrule);
 
             if (serviceFundflowrules == null || serviceFundflowrules.stream().count() == 0) {
@@ -519,6 +526,28 @@
                     }
                 }
                 FlowLevel = FlowLevel + 1;
+
+                if (serviceFund.getFlowlevel() == 1 && serviceFund.getBackflowlevel() == 100) {
+                    log.info("璐㈠姟閫�鍥炲啀鎻愪氦锛屽嚭绾冲啀娆″鎵癸紝涔嬪悗鎻愪氦鍒拌储鍔�");
+                    //璇存槑鏄储鍔¢��鍥炲啀鎻愪氦鐨�.闇�瑕佸嚭绾冲啀鐪嬩竴閬嶏紝娌¢棶棰樹箣鍚庯紝寰�鍒嗕韩琛ㄩ噷鏂板
+                    serviceFundService.addFundSharedInfo(serviceFund.getId());
+                    serviceFund.setFlowlevel(100L);
+                    serviceFund.setRecordstatus(99);
+                    serviceFundService.updateById(serviceFund);
+
+                    //淇濆瓨瀹℃壒娴佺▼琛�
+                    ServiceFundflow serviceFundflow = new ServiceFundflow();
+                    SysUser user = loginUser.getUser();
+                    serviceFundflow.setFundid(serviceFund.getId());
+                    serviceFundflow.setCheckuserno(user.getUserName());
+                    serviceFundflow.setCheckusername(user.getNickName());
+                    serviceFundflow.setFundtype(2);
+                    serviceFundflow.setApplytype(serviceFund.getApplytype());
+                    serviceFundflow.setFlowconclusion(CheckFlag);
+                    serviceFundflow.setFlowcontent("閫氳繃");
+                    Boolean aBoolean = serviceFundflowService.saveData(serviceFundflow);
+                    return AjaxResult.success();
+                }
                 //璁板綍涓�涓嬶紝涓嬩竴绾х殑瀹℃壒锛屼互渚夸簬涓嬩竴绾ч��鍥炲悗锛屽彂璧疯�呮彁浜ゆ椂锛岃兘鍐嶆彁鍒板綋鍓嶅鎵瑰眰绾�
                 serviceFund.setBackflowlevel(FlowLevel);
             } else {
@@ -619,16 +648,32 @@
             return toAjax(false);
         }
         for (ServiceFund sf : infoByInfoIdList) {
+            sf.setApplyTime(new Date());
             //濡傛灉绛変簬100锛岃鏄庡凡缁忚蛋鍒板尰闄㈣储鍔¢偅杈逛簡锛涜储鍔¢偅杈瑰彇鏁版嵁鏄粠鍒嗕韩琛ㄥ彇锛屾墍浠ワ紝杩欓噷鐩存帴寰�鍒嗕韩琛ㄩ噷娣诲姞鏁版嵁灏辫浜�
             if (sf.getBackflowlevel() != null && sf.getBackflowlevel() == 199) {
                 //灏唂und琛ㄧ殑瀹℃牳鐘舵�佹敼鎴�100
                 sf.setBackflowlevel(100);
+
+                //閫�鍥炲啀鎻愪氦锛岄渶瑕佸啀鍒板嚭绾抽偅閲�
+                sf.setFlowlevel(1L);
+                sf.setRecordstatus(0);
                 serviceFundService.updateById(sf);
 
-                //寰�鍒嗕韩琛ㄩ噷鏂板
-                serviceFundService.addFundSharedInfo(serviceFund.getId());
+//                //寰�鍒嗕韩琛ㄩ噷鏂板
+//                serviceFundService.addFundSharedInfo(serviceFund.getId());
 
                 return success();
+            } else if (sf.getBackflowlevel() != null && sf.getBackflowlevel() == 100) {
+                //璐㈠姟閫�鍥炵殑鏁版嵁鍐嶆彁浜わ紝鍒板嚭绾抽偅閲屾病鏈夎繃锛屽啀閫�鍥烇紝瀵艰嚧backflowlevel鏄�100,
+                //閫�鍥炲啀鎻愪氦锛岄渶瑕佸啀鍒板嚭绾抽偅閲�
+                sf.setFlowlevel(1L);
+                sf.setRecordstatus(2);
+                serviceFundService.updateById(sf);
+            } else if (sf.getBackflowlevel() != null && sf.getBackflowlevel() == 2) {
+                //鑱傜閫�鍥炵殑锛屼篃闇�瑕佸厛鍒板嚭绾抽偅閲�
+                sf.setFlowlevel(1L);
+                sf.setRecordstatus(2);
+                serviceFundService.updateById(sf);
             } else {
 
                 Integer TotalLevel = 0;
@@ -663,6 +708,7 @@
 
         return toAjax(false);
     }
+
 
     /**
      * 鍒犻櫎璐圭敤鐢宠涓�
@@ -715,6 +761,7 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
@@ -990,11 +1037,13 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
     private void getDataSS(Map dataMap, Long id) {
         ServiceFund serviceFund = serviceFundService.getById(id);
+        log.info("閫氳繃id鏌ヨ鏁版嵁鐨勭粨鏋滐細{}", serviceFund);
         if (serviceFund == null) {
             throw new ServiceException("涓嬭浇澶辫触锛岀敤鎴蜂俊鎭嚭閿�", HttpStatus.NO_CONTENT);
         }
@@ -1090,11 +1139,13 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
     private String getDataYX(Map dataMap, Long id) {
         ServiceFund serviceFund = serviceFundService.getById(id);
+        log.info("閫氳繃id鑾峰彇鍖诲銆佸姙鍏�佺哗鏁堟垚鏈殑fund淇℃伅涓猴細{}", serviceFund);
         if (serviceFund == null) {
             throw new ServiceException("涓嬭浇澶辫触锛岀敤鎴蜂俊鎭嚭閿�", HttpStatus.NO_CONTENT);
         }
@@ -1120,7 +1171,8 @@
             throw new ServiceException("涓嬭浇澶辫触锛屾病鏈夊搴斾俊鎭�", HttpStatus.NO_CONTENT);
         }
 
-        Date dt = serviceFund.getCreateTime();
+//        Date dt = serviceFund.getCreateTime();
+        Date dt = serviceFund.getApplyTime();
         SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
         String date = formatter.format(dt);
         String time = date.substring(0, 10);
@@ -1137,51 +1189,67 @@
         dataMap.put("YWZ", serviceFund.getDeptmentname() == null ? "" : serviceFund.getDeptmentname());
         dataMap.put("ZHUZANG", serviceFund.getManagername() == null ? "" : serviceFund.getManagername());
 
+        dataMap.put("FYMC", LocalDate.now().getYear() + "骞�" + LocalDate.now().getMonthValue() + "鏈堜汉浣撳櫒瀹樿幏鍙栨湇鍔$鐞嗕腑蹇冨伐浣滀汉鍛樼哗鏁�");
+
         String bz = "";
         int i = 0;
-        for (ServiceFunddetail f : fd) {
-            seqno++;
+        if (!serviceFund.getApplytype().equals("5")) {
+            for (ServiceFunddetail f : fd) {
+                seqno++;
+                Map<String, Object> map = new HashMap<String, Object>();
+                map.put("seqno", seqno);
+
+                //濡傛灉鏄尰鐤楁垚鏈紝鍒欐妸閾惰鍗″姞涓婃瘡鏉℃槑缁嗙殑鍚庨潰
+                if (serviceFund.getApplytype().equals("3")) {
+                    i = i + 1;
+                    bz += f.getBeneficiaryname() == null ? "(" + i + ")" : "(" + i + ")" + f.getBeneficiaryname() + "锛�";
+                    bz += "閲戦 : " + f.getAmount() + "鍏�" + "锛�";
+                    bz += f.getDepositbank() == null ? "" : f.getDepositbank() + ": ";
+                    bz += f.getBankcardno() == null ? "" : f.getBankcardno();
+                    bz += "<w:br/>";
+                }
+                if (serviceFund.getApplytype().equals("4")) {
+                    i = i + 1;
+                    bz += f.getBeneficiaryname() == null ? "(" + i + ")" : "(" + i + ")" + f.getBeneficiaryname() + "锛�";
+                    bz += "閲戦 : " + f.getAmount() + "鍏�" + "锛�";
+                    bz += f.getDepositbank() == null ? "" : f.getDepositbank() + ": ";
+                    bz += f.getBankcardno() == null ? "" : f.getBankcardno();
+                    bz += "<w:br/>";
+                }
+
+
+                String fyxm = "";
+                fyxm += f.getItemname() == null ? "" : f.getItemname();
+                fyxm += f.getAmount() + "鍏�";
+                if (f.getItemname() == null && f.getAmount() == 0.0) {
+                    fyxm = "";
+                }
+                map.put("FYXM", fyxm);
+                newList.add(map);
+            }
+        } else {
             Map<String, Object> map = new HashMap<String, Object>();
-            map.put("seqno", seqno);
-//            String fyxm = "";
-//            fyxm += f.getItemname() == null ? "" : f.getItemname();
-//            fyxm += f.getAmount() + "鍏�";
-//            //濡傛灉鏄尰鐤楁垚鏈紝鍒欐妸閾惰鍗″姞涓婃瘡鏉℃槑缁嗙殑鍚庨潰
-//            if (serviceFund.getApplytype().equals("3")) {
-//                fyxm += "(";
-//                fyxm += f.getUnitname() == null ? "" : f.getUnitname() + ";";
-//                fyxm += f.getDepositbank() == null ? "" : f.getDepositbank() + ": ";
-//                fyxm += f.getBankcardno() == null ? "" : f.getBankcardno();
-//                fyxm += ")";
-//            }
-
-            //濡傛灉鏄尰鐤楁垚鏈紝鍒欐妸閾惰鍗″姞涓婃瘡鏉℃槑缁嗙殑鍚庨潰
-            if (serviceFund.getApplytype().equals("3")) {
-                i = i + 1;
-                bz += f.getBeneficiaryname() == null ? "(" + i + ")" : "(" + i + ")" + f.getBeneficiaryname() + "锛�";
-                bz += "閲戦 : " + f.getAmount() + "鍏�" + "锛�";
-                bz += f.getDepositbank() == null ? "" : f.getDepositbank() + ": ";
-                bz += f.getBankcardno() == null ? "" : f.getBankcardno();
-                bz += "<w:br/>";
-            }
-            if (serviceFund.getApplytype().equals("4")) {
-                i = i + 1;
-                bz += f.getBeneficiaryname() == null ? "(" + i + ")" : "(" + i + ")" + f.getBeneficiaryname() + "锛�";
-                bz += "閲戦 : " + f.getAmount() + "鍏�" + "锛�";
-                bz += f.getDepositbank() == null ? "" : f.getDepositbank() + ": ";
-                bz += f.getBankcardno() == null ? "" : f.getBankcardno();
-                bz += "<w:br/>";
-            }
-
+            map.put("seqno", 1);
             String fyxm = "";
-            fyxm += f.getItemname() == null ? "" : f.getItemname();
-            fyxm += f.getAmount() + "鍏�";
-            if (f.getItemname() == null && f.getAmount() == 0.0) {
+            fyxm += LocalDate.now().getYear() + "骞�" + LocalDate.now().getMonthValue() + "鏈堜汉浣撳櫒瀹樿幏鍙栨湇鍔$鐞嗕腑蹇冨伐浣滀汉鍛樼哗鏁�,鍏辫";
+            fyxm += serviceFund.getPretaxcost() + "鍏�";
+            if (serviceFund.getPretaxcost() == null && serviceFund.getPretaxcost() == 0.0) {
                 fyxm = "";
             }
             map.put("FYXM", fyxm);
             newList.add(map);
+            Map<String, Object> objectObjectHashMap = new HashMap<>();
+            objectObjectHashMap.put("seqno", 2);
+            objectObjectHashMap.put("FYXM", "");
+            newList.add(objectObjectHashMap);
+
+            Map<String, Object> objectObjectHashMap2 = new HashMap<>();
+            objectObjectHashMap2.put("seqno", 3);
+            objectObjectHashMap2.put("FYXM", "");
+            newList.add(objectObjectHashMap2);
         }
+
+
         //鍚堝苟鍗曞厓鏍�
         checkList(newList);
         dataMap.put("items", newList);
@@ -1286,6 +1354,7 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
@@ -1354,6 +1423,7 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
@@ -1853,6 +1923,7 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
@@ -1941,6 +2012,7 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
@@ -2039,6 +2111,7 @@
     /**
      * 璐圭敤绫诲瀷璁℃暟
      */
+//    @NotRepeatCommit(key = "param:arg[1]", value = 30000)
     @ApiOperation("璐圭敤绫诲瀷璁℃暟")
     @GetMapping(value = "/countItem/{infoid}/{itemid}")
     public AjaxResult countItem(@PathVariable Long infoid, @PathVariable Long itemid) {
@@ -2060,4 +2133,35 @@
         return AjaxResult.success(serviceFundService.performance(serviceFundVO));
     }
 
+    /**
+     * 鍚堣涓◣
+     */
+    @NotRepeatCommit(key = "param:arg[1]", value = 30000)
+    @ApiOperation("鍚堣涓◣")
+    @Log(title = "鍚堣涓◣", businessType = BusinessType.INSERT)
+    @PostMapping("/totaltax")
+    public AjaxResult totaltax(@RequestBody TotalTaxVO totalTaxVO) {
+        Map<String, List<ServiceFunddetailExcel>> totaltax = serviceFundService.totaltax(totalTaxVO);
+        if (ObjectUtils.isEmpty(totaltax)) {
+            throw new BaseException("鍚堣涓◣澶辫触");
+        }
+
+        Set<String> strings = totaltax.keySet();
+        String key2 = null;
+        for (String key : strings) {
+            key2 = key;
+        }
+        ExcelUtil<ServiceFunddetailExcel> util = new ExcelUtil<ServiceFunddetailExcel>(ServiceFunddetailExcel.class);
+        AjaxResult ajaxResult = util.exportExcel(totaltax.get(key2), key2);
+        String msg = (String) ajaxResult.get("msg");
+
+        Map dataMap = new HashMap();
+        dataMap.put("downloadUrl", "/profile/download/" + msg);
+        dataMap.put("downloadName", msg);
+
+        return AjaxResult.success(dataMap);
+
+
+    }
+
 }

--
Gitblit v1.9.3