From d51450c60f95c7e6fb7034451e9c1f7497b2b116 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期四, 31 八月 2023 17:38:07 +0800
Subject: [PATCH] 代码提交

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceFundController.java |   74 +++++++++++++++++++++++++++++++------
 1 files changed, 62 insertions(+), 12 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 737e585..69f9cbe 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
@@ -76,6 +76,9 @@
     @Autowired
     private IServiceFundSharedService fundServiceShare;
 
+    @Autowired
+    private IServiceExternalpersonService externalpersonService;
+
 
     public ServiceFundController() {
         configuration = new Configuration();
@@ -513,7 +516,11 @@
             serviceFundflow.setFundtype(2);
             serviceFundflow.setApplytype(serviceFund.getApplytype());
             serviceFundflow.setFlowconclusion(CheckFlag);
-            serviceFundflow.setFlowcontent(checkFundVO.getFlowcontent());
+            if (org.apache.commons.lang.StringUtils.isNotBlank(checkFundVO.getFlowcontent())) {
+                serviceFundflow.setFlowcontent(checkFundVO.getFlowcontent());
+            } else {
+                serviceFundflow.setFlowcontent(checkFundVO.getFlowconclusion() == 1 ? "閫氳繃" : "涓嶉�氳繃");
+            }
             serviceFundflow.setFlowlevel(OriginalFlowLevel + 1);
             serviceFundflowService.save(serviceFundflow);
             serviceFundService.updateById(serviceFund);
@@ -651,6 +658,7 @@
         String date = formatter.format(dt);
         String time = date.substring(0, 10);
 
+        dataMap.put("XZBH", serviceFund.getBh() == null ? "" : serviceFund.getBh());
         dataMap.put("TBYYMMDD", time);
         dataMap.put("BXDFJ", serviceFund.getAttachcount() == 0 ? "   " : serviceFund.getAttachcount());
         dataMap.put("JXZXM", serviceFund.getDonorname() == null ? "" : serviceFund.getDonorname());
@@ -964,7 +972,7 @@
     @GetMapping(value = "/downloadYX/{id}")
     public Map downloadInfoYX(@PathVariable("id") Long id) throws IOException {
         Map dataMap = new HashMap();
-        getDataYX(dataMap, id);
+        String dataYX = getDataYX(dataMap, id);
         String filePath = getClass().getResource("/template/").getPath();
         System.out.println(filePath);
         //璁剧疆妯℃湰瑁呯疆鏂规硶鍜岃矾寰�,FreeMarker鏀寔澶氱妯℃澘瑁呰浇鏂规硶銆傚彲浠ラ噸servlet锛宑lasspath锛屾暟鎹簱鏁欑▼瑁呰浇锛�
@@ -973,13 +981,22 @@
         Template t = null;
         try {
             //鎹愮尞琛�.ftl涓鸿瑁呰浇鐨勬ā鏉�
-            t = configuration.getTemplate("鍖诲鎴愭湰璐圭敤鐢宠鍗�.ftl");
+            //涓撳鍔冲姟璐圭敵璇� 1    浼︾悊璇勪及鍔冲姟璐圭敵璇� 2    鍖诲鎴愭湰璐圭敤鐢宠 3     鍔炲叕璐圭敤鎶ラ攢鐢宠 4
+            if (dataYX.equals("3")) {
+                t = configuration.getTemplate("鍖诲鎴愭湰璐圭敤鐢宠鍗�.ftl");
+            } else if (dataYX.equals("4")) {
+                t = configuration.getTemplate("鍔炲叕璐圭敤鐢宠鍗�.ftl");
+            }
         } catch (IOException e) {
             e.printStackTrace();
         }
         String newTime = String.valueOf(Calendar.getInstance().getTimeInMillis());
-        String name = "鍖诲鎴愭湰璐圭敤鐢宠鍗昣" + dataMap.get("XM") + "_" + newTime;
-
+        String name = null;
+        if (dataYX.equals("3")) {
+            name = "鍖诲鎴愭湰璐圭敤鐢宠鍗昣" + dataMap.get("XM") + "_" + newTime;
+        } else if (dataYX.equals("4")) {
+            name = "鍔炲叕璐圭敤鐢宠鍗昣" + dataMap.get("XM") + "_" + newTime;
+        }
         //杈撳嚭鏂囨。璺緞鍙婂悕绉�
         File outFile = new File(RuoYiConfig.getProfile() + "/download/wordtemplate/" + name + ".doc");
         Writer out = null;
@@ -1000,10 +1017,14 @@
         return map;
     }
 
-    private void getDataYX(Map dataMap, Long id) {
+    private String getDataYX(Map dataMap, Long id) {
         ServiceFund serviceFund = serviceFundService.getById(id);
         if (serviceFund == null) {
             throw new ServiceException("涓嬭浇澶辫触锛岀敤鎴蜂俊鎭嚭閿�", HttpStatus.NO_CONTENT);
+        }
+        ServiceExternalperson infoByUserNo = null;
+        if (StringUtils.isNotBlank(serviceFund.getUserno())) {
+            infoByUserNo = externalpersonService.getInfoByUserNo(serviceFund.getUserno());
         }
 
         List<ServiceFunddetail> fd = serviceFunddetailService.getAllDetailsByFDIDHZ(id);
@@ -1019,10 +1040,13 @@
         List<Map<String, Object>> newList = new ArrayList<Map<String, Object>>();
         int seqno = 0;
 
+        dataMap.put("XZBH", serviceFund.getBh() == null ? "" : serviceFund.getBh());
         dataMap.put("TBYYMMDD", time);
         dataMap.put("BXDFJ", serviceFund.getAttachcount() == 0 ? "   " : serviceFund.getAttachcount());
         dataMap.put("JXZXM", serviceFund.getDonorname() == null ? "" : serviceFund.getDonorname());
         dataMap.put("JSR", serviceFund.getUsername() == null ? "" : serviceFund.getUsername());
+        dataMap.put("YWZ", serviceFund.getDeptmentname() == null ? "" : serviceFund.getDeptmentname());
+        dataMap.put("ZHUZANG", serviceFund.getManagername() == null ? "" : serviceFund.getManagername());
 
         for (ServiceFunddetail f : fd) {
             seqno++;
@@ -1031,21 +1055,30 @@
             String fyxm = "";
             fyxm += f.getItemname() == null ? "" : f.getItemname();
             fyxm += f.getAmount() + "鍏�";
-            fyxm += "(";
-            fyxm += f.getUnitname() == null ? "" : f.getUnitname() + ";";
-            fyxm += f.getDepositbank() == null ? "" : f.getDepositbank() + ": ";
-            fyxm += f.getBankcardno() == null ? "" : f.getBankcardno();
-            fyxm += ")";
+//            fyxm += "(";
+//            fyxm += f.getUnitname() == null ? "" : f.getUnitname() + ";";
+//            fyxm += f.getDepositbank() == null ? "" : f.getDepositbank() + ": ";
+//            fyxm += f.getBankcardno() == null ? "" : f.getBankcardno();
+//            fyxm += ")";
             map.put("FYXM", fyxm);
             newList.add(map);
         }
+        //鍚堝苟鍗曞厓鏍�
+        checkList(newList);
         dataMap.put("items", newList);
 
         dataMap.put("JEXS", serviceFund.getPretaxcost());
         dataMap.put("JEDS", convert(serviceFund.getPretaxcost()) + "鏁�");
 //        dataMap.put("JEXS", serviceFund.getAmountrequested());
 //        dataMap.put("JEDS", convert(serviceFund.getAmountrequested()) + "鏁�");
-        dataMap.put("BXBZ", serviceFund.getRemark() == null ? "" : serviceFund.getRemark());
+        //澶囨敞閲屾斁鐨勬槸缁忓姙浜虹殑閾惰鍗′俊鎭�
+        dataMap.put("BXBZ", infoByUserNo == null ? "" : infoByUserNo.getBranchbankname() + "  " + infoByUserNo.getBankcardno());
+        dataMap.put("YZ", serviceFund.getPresident() == null ? "" : serviceFund.getPresident());
+        dataMap.put("CWFYZ", serviceFund.getFinvicepresident() == null ? "" : serviceFund.getFinvicepresident());
+        dataMap.put("YWFYZ", serviceFund.getBusvicepresident() == null ? "" : serviceFund.getBusvicepresident());
+        dataMap.put("BGSZR", serviceFund.getOfficedirector() == null ? "" : serviceFund.getOfficedirector());
+        dataMap.put("CWBZR", serviceFund.getFinancedirector() == null ? "" : serviceFund.getFinancedirector());
+        dataMap.put("CWSH", serviceFund.getFinancechecher() == null ? "" : serviceFund.getFinancechecher());
 
         dataMap.put("YYMMDD", time);
         dataMap.put("XM", serviceFund.getDonorname() == null ? "" : serviceFund.getDonorname());
@@ -1075,6 +1108,21 @@
 
         dataMap.put("list", newsList);
         dataMap.put("BYHJ", hj);
+        dataMap.put("BGSZR2", serviceFund.getOfficedirector() == null ? "" : serviceFund.getOfficedirector());
+        dataMap.put("CWBZR2", serviceFund.getFinancedirector() == null ? "" : serviceFund.getFinancedirector());
+        dataMap.put("CWSH2", serviceFund.getFinancechecher() == null ? "" : serviceFund.getFinancechecher());
+
+        return serviceFund.getApplytype();
+    }
+
+    public List<Map<String, Object>> checkList(List<Map<String, Object>> list) {
+        String start = "<w:vMerge w:val='restart'/>";
+        String end = "<w:vMerge/>";
+        list.get(0).put("start", start);
+        for (int i = 1; i < list.size(); i++) {
+            list.get(i).put("end", end);
+        }
+        return list;
 
     }
 
@@ -1699,6 +1747,7 @@
         String date = formatter.format(dt);
         String time = date.substring(0, 10);
 
+        dataMap.put("XZBH", serviceFund.getBh() == null ? "" : serviceFund.getBh());
         dataMap.put("YYMMDD", time);
         dataMap.put("XM", serviceFund.getDonorname() == null ? "" : serviceFund.getDonorname());
         dataMap.put("GZRY", serviceFund.getUsername() == null ? "" : serviceFund.getUsername());
@@ -1785,6 +1834,7 @@
         String date = formatter.format(dt);
         String time = date.substring(0, 10);
 
+        dataMap.put("XZBH", serviceFund.getBh() == null ? "" : serviceFund.getBh());
         dataMap.put("TBYYMMDD", time);
         dataMap.put("BXDFJ", serviceFund.getAttachcount() == 0 ? "   " : serviceFund.getAttachcount());
         dataMap.put("JXZXM", serviceFund.getDonorname() == null ? "" : serviceFund.getDonorname());

--
Gitblit v1.9.3