From b6dd47b05107fc36d8ff4f7f29a4446521f95503 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期四, 02 一月 2025 18:44:28 +0800
Subject: [PATCH] 代码提交

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/project/ServiceFundController.java |  624 +++++++++++++++++++++++++++++---------------------------
 1 files changed, 327 insertions(+), 297 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 29c9092..9f109d1 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,6 +1,8 @@
 package com.ruoyi.web.controller.project;
 
+import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
 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;
@@ -11,7 +13,7 @@
 import com.ruoyi.common.core.page.TableDataInfo;
 import com.ruoyi.common.enums.BusinessType;
 import com.ruoyi.common.exception.ServiceException;
-import com.ruoyi.common.tax.TaxtUtils;
+import com.ruoyi.common.exception.base.BaseException;
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.common.utils.bean.DtoConversionUtils;
@@ -21,6 +23,7 @@
 import com.ruoyi.project.mapper.ServiceFunddetailMapper;
 import com.ruoyi.project.service.*;
 import com.ruoyi.system.service.ISysPostService;
+import com.ruoyi.system.service.ISysUserService;
 import freemarker.template.Configuration;
 import freemarker.template.Template;
 import freemarker.template.TemplateException;
@@ -35,7 +38,9 @@
 import java.io.*;
 import java.math.BigDecimal;
 import java.text.SimpleDateFormat;
+import java.time.LocalDate;
 import java.util.*;
+import java.util.concurrent.ConcurrentHashMap;
 import java.util.stream.Collectors;
 
 import static com.ruoyi.web.controller.project.ServiceReimbursementController.convert;
@@ -73,10 +78,7 @@
     private IServiceReimbursementService serviceReimbursementService;
 
     @Autowired
-    private IServiceSystemmessageService ServiceSystemmessage;
-
-    @Autowired
-    private IBaseOnlyvalueService baseOnlyvalueService;
+    private IServiceSystemmessageService iServiceSystemmessageService;
 
     @Autowired
     private IServiceExternalpersonService externalpersonService;
@@ -84,6 +86,12 @@
     @Autowired
     private ISysPostService postService;
 
+
+    @Autowired
+    private DingTalkService dingTalkService;
+
+    @Autowired
+    private ISysUserService sysUserService;
 
     public ServiceFundController() {
         configuration = new Configuration();
@@ -94,7 +102,7 @@
      * 鏌ヨ璐圭敤鐢宠涓诲垪琛�
      */
     @ApiOperation("鏌ヨ璐圭敤鐢宠涓诲垪琛�")
-    //@PreAuthorize("@ss.hasPermi('project:fund:list')")
+    //// @PreAuthorize("@ss.hasPermi('project:fund:list')")
     @GetMapping("/list")
     public TableDataInfo list(ServiceFund serviceFund) {
         startPage();
@@ -130,6 +138,10 @@
         Integer pageSize = spFinancialExpensesIn.getPageSize();
         Integer checkstatus = spFinancialExpensesIn.getCheckstatus();
 
+        String donorname = spFinancialExpensesIn.getDonorname();
+        if (StringUtils.isEmpty(donorname)) {
+            donorname = null;
+        }
         if (pageNum == null) {
             pageNum = 1;
         }
@@ -151,7 +163,7 @@
         }
 
         //startPage();
-        List<SpFinancialExpensesFundOut> list = serviceFundService.getListBypower(loginUser.getUsername(), 2, APPLICANT, APPLICATIONBEGTIME, APPLICATIONENDTIME, loginUser.getDeptId().toString(), CHECKFLAG, APPLYTYPE,checkstatus);
+        List<SpFinancialExpensesFundOut> list = serviceFundService.getListBypower(loginUser.getUsername(), 2, APPLICANT, APPLICATIONBEGTIME, APPLICATIONENDTIME, loginUser.getDeptId().toString(), CHECKFLAG, APPLYTYPE, checkstatus, donorname);
         //閫氳繃鎹愮尞鑰呰繃婊�
         if (StringUtils.isNotEmpty(spFinancialExpensesIn.getDonorname())) {
             list = list.stream().filter(obj -> obj.getDonorname().contains(spFinancialExpensesIn.getDonorname())).collect(Collectors.toList());
@@ -166,14 +178,25 @@
         Collections.sort(list, new Comparator<SpFinancialExpensesFundOut>() {
             @Override
             public int compare(SpFinancialExpensesFundOut o1, SpFinancialExpensesFundOut o2) {
-                return o1.getCreateTime().compareTo(o2.getCreateTime());
+                return o1.getApplyTime().compareTo(o2.getApplyTime());
             }
         });
         return getCustomDataTable(list, pageNum, pageSize);
     }
 
+    /**
+     * 鏍规嵁鏉冮檺鏄剧ず瀹℃牳鍒楄〃
+     */
+    @ApiOperation("鏍规嵁鏉冮檺鏄剧ず瀹℃牳鍒楄〃")
+    @Log(title = "鏍规嵁鏉冮檺鏄剧ず瀹℃牳鍒楄〃", businessType = BusinessType.OTHER)
+    @PostMapping("/getExpertfeeList")
+    public TableDataInfo getExpertfeeList(@RequestBody SpSelectExpertfee spSelectExpertfee) {
+        List<SpFinancialExpensesFundOut> expertfeeList = serviceFundService.getExpertfeeList(spSelectExpertfee);
+        return getCustomDataTable(expertfeeList, spSelectExpertfee.getPageNum(), spSelectExpertfee.getPageSize());
+    }
+
     @ApiOperation("鏌ヨ璐圭敤鐢宠涓诲垪琛�")
-    //@PreAuthorize("@ss.hasPermi('project:fund:list')")
+    //// @PreAuthorize("@ss.hasPermi('project:fund:list')")
     @GetMapping(value = "/getInfo/{infoid}")
     public AjaxResult getInfoByInfoId(@PathVariable("infoid") Long infoid) {
         return AjaxResult.success(serviceFundService.getInfoByInfoId(infoid));
@@ -195,7 +218,7 @@
      * 瀵煎嚭璐圭敤鐢宠涓诲垪琛�
      */
     @ApiOperation("瀵煎嚭璐圭敤鐢宠涓诲垪琛�")
-    //@PreAuthorize("@ss.hasPermi('project:fund:export')")
+    //// @PreAuthorize("@ss.hasPermi('project:fund:export')")
     @Log(title = "璐圭敤鐢宠涓�", businessType = BusinessType.EXPORT)
     @GetMapping("/export")
     public AjaxResult export(ServiceFund serviceFund) {
@@ -209,7 +232,7 @@
      * 鑾峰彇璐圭敤鐢宠涓昏缁嗕俊鎭�
      */
     @ApiOperation("鑾峰彇璐圭敤鐢宠涓昏缁嗕俊鎭�")
-    //@PreAuthorize("@ss.hasPermi('project:fund:query')")
+    //// @PreAuthorize("@ss.hasPermi('project:fund:query')")
     @GetMapping(value = "/{id}")
     public AjaxResult getInfo(@PathVariable("id") Long id) {
         return AjaxResult.success(serviceFundService.getById(id));
@@ -219,9 +242,9 @@
      * 鏂板璐圭敤鐢宠涓�
      */
     @ApiOperation("鏂板璐圭敤鐢宠涓�")
-    //@PreAuthorize("@ss.hasPermi('project:fund:add')")
+    //// @PreAuthorize("@ss.hasPermi('project:fund:add')")
     @Log(title = "璐圭敤鐢宠涓�", businessType = BusinessType.INSERT)
-    @PostMapping
+    @PostMapping("/add")
     @RepeatSubmit
     @Options(useGeneratedKeys = true, keyProperty = "id")
     public AjaxResult add(@RequestBody ServiceFund serviceFund) {
@@ -233,216 +256,15 @@
         return AjaxResult.success(id);
     }
 
-
-//    public int addReiSharedDatd(ServiceFund serviceFund, int nType) {
-//        //remShare = ;
-//        ServiceFundShared remShare = null;
-//        if (nType == 1) {
-//            remShare = new ServiceFundShared();
-//            remShare.setSerfunid(serviceFund.getId());
-//        } else //modify
-//        {
-//            List<ServiceFundShared> remlist = fundServiceShare.getFundShareInfoById(serviceFund.getId());
-//            if (remlist != null) remShare = remlist.get(0);
-//        }
-//
-//        remShare.setDonorno(serviceFund.getDonorno());
-//        remShare.setDonorname(serviceFund.getDonorname());
-//        remShare.setUserno(serviceFund.getUserno());
-//        remShare.setUsername(serviceFund.getUsername());
-//        remShare.setUnitname(serviceFund.getUnitname());
-//        remShare.setUnitno(serviceFund.getUnitno());
-//        remShare.setUnituserno(serviceFund.getUnituserno());
-//        remShare.setPhone(serviceFund.getPhone());
-//        remShare.setAnnexbankcard(serviceFund.getAnnexbankcard());
-//        remShare.setAnnexregistform(serviceFund.getAnnexregistform());
-//        Double nTemp = serviceFund.getPretaxcost();
-//        if (nTemp == null) nTemp = 0d;
-//        remShare.setPretaxcost(BigDecimal.valueOf(nTemp));
-//        //remShare.setAnnexfiles(serviceReimbursement.getAnnexfiles());
-//        // remShare.setAmountrequested(BigDecimal.valueOf(serviceReimbursement.getAmountrequested()));
-//
-//        nTemp = serviceFund.getTaxedcost();
-//        if (nTemp == null) nTemp = 0d;
-//        remShare.setTaxedcost(BigDecimal.valueOf(nTemp));
-//
-//        nTemp = serviceFund.getTotalcost();
-//        if (nTemp == null) nTemp = 0d;
-//        remShare.setTotalcost(BigDecimal.valueOf(nTemp));
-//
-//        nTemp = serviceFund.getExpertcost();
-//        if (nTemp == null) nTemp = 0.0;
-//        remShare.setExpertcost(BigDecimal.valueOf(nTemp));
-//
-//        nTemp = serviceFund.getEthicscost();
-//        if (nTemp == null) nTemp = 0.0;
-//        remShare.setEthicscost(BigDecimal.valueOf(nTemp));
-//
-//        nTemp = serviceFund.getMedicalcost();
-//        if (nTemp == null) nTemp = 0.0;
-//        remShare.setMedicalcost(BigDecimal.valueOf(nTemp));
-//
-//        nTemp = serviceFund.getFamilycost();
-//        if (nTemp == null) nTemp = 0.0;
-//        remShare.setFamilycost(BigDecimal.valueOf(nTemp));
-//
-//        nTemp = serviceFund.getAftercarecost();
-//        if (nTemp == null) nTemp = 0.0;
-//        remShare.setAftercarecost(BigDecimal.valueOf(nTemp));
-//
-//        nTemp = serviceFund.getAmountrequested();
-//        if (nTemp == null) nTemp = 0.0;
-//        remShare.setAmountrequested(BigDecimal.valueOf(nTemp));
-//
-//
-//        remShare.setApplytype(serviceFund.getApplytype());
-//
-//        nTemp = serviceFund.getPrepaidamount();
-//        if (nTemp == null) nTemp = 0.0;
-//        remShare.setPrepaidamount(BigDecimal.valueOf(nTemp));
-//
-//        remShare.setInvoicecount(serviceFund.getInvoicecount());
-//        remShare.setAttachcount(serviceFund.getAttachcount());
-//        remShare.setManagerno(serviceFund.getManagerno());
-//        remShare.setManagername(serviceFund.getManagername());
-//        remShare.setDeptmentno(serviceFund.getDeptmentno());
-//        remShare.setDeptmentname(serviceFund.getDeptmentname());
-//        remShare.setOpochecker(serviceFund.getOpochecker());
-//        remShare.setFinvicepresident(serviceFund.getFinvicepresident());
-//        remShare.setBusvicepresident(serviceFund.getBusvicepresident());
-//        remShare.setOfficedirector(serviceFund.getOfficedirector());
-//        remShare.setFinancedirector(serviceFund.getFinancedirector());
-//        remShare.setFinancechecher(serviceFund.getFinancechecher());
-//        //remShare.setIsdistribute(serviceFund.getIsdistribute());
-//        remShare.setRecordstatus(serviceFund.getRecordstatus());
-//        remShare.setUploadflag(serviceFund.getUploadflag());
-//        remShare.setUploadtime(serviceFund.getUploadtime());
-//        long nLevel = serviceFund.getFlowlevel();
-//        remShare.setFlowlevel(nLevel);
-//
-//        remShare.setInfoid(serviceFund.getInfoid());
-//
-//        //remShare.setOaid(serviceReimbursement.getOaid());
-//        //remShare.setDonorno(serviceReimbursement.getDonorno());
-//
-//        boolean bRet = false;
-//        if (nType == 1) {
-//            bRet = fundServiceShare.save(remShare);
-//        } else {
-//            //remShare.setId(serviceReimbursement.);
-//            bRet = fundServiceShare.updateById(remShare);
-//        }
-//
-//        //if(!bRet) return -1;
-//        String strMutfileUrl = remShare.getAnnexbankcard();
-//        //鏈夐檮浠舵椂鎵嶈皟鐢ㄧ涓夋柟杩涜涓婁紶
-//        if (strMutfileUrl == null) return 0;
-//        if (strMutfileUrl.isEmpty()) return 0;
-//
-//        try {
-//            uploadOAFileAndUpdateDb(remShare);
-//        } catch (Exception e) {
-//            logger.error("璋冪敤绗笁鏂规帴鍙e嚭閿�!");
-//            e.printStackTrace();
-//        }
-//
-//        //姝ゅ淇濆瓨鎴愬姛鍚庤涓婁紶OA锛屼繚瀛樿繑鍥炲��
-//
-//        return 0;
-//    }
-
-
-//    int uploadOAFileAndUpdateDb(ServiceFundShared remShare) {
-//        //涓婁紶OA鏂囦欢
-//        //String strUrl = "http://129.88.242.39:8899/seeyon/rest/token?userName=opo&password=127814f8-84e8-4304-84a5-a71573567efd&loginName=demo3";
-//        String strUrl = "http://129.88.242.39:8899/seeyon/rest/token";
-//        //String strUrl = "http://slb.hospitalstar.com:8899/seeyon/rest/token";
-//        //涓婁紶鏂囦欢鎴愬姛鍚庯紝鍘绘洿鏂扮浉鍏崇殑鏁版嵁搴�
-//
-//
-//        Map<String, Object> map = new HashMap<String, Object>();
-//        map.put("userName", "opo");
-//        map.put("password", "4126407a-9821-4874-be41-6568abd6dbe5");
-//        map.put("loginName", "demo3");
-//
-//        JSONObject jsonObj = new JSONObject(map);
-//
-//        System.out.println("uploadOAFileAndUpdateDb + jsonObject" + jsonObj.toString() + "\r\n" + jsonObj.toJSONString());
-//        String strRes = HttpClientKit.postOpr(strUrl, jsonObj.toString());//
-//        //String strRes = HttpClientKit.postMsg(strUrl,jsonObj);//寰楀埌杩斿洖鐨則oken?
-//
-//        JSONObject json1 = JSONObject.parseObject(strRes);
-//        strRes = json1.get("id").toString();
-//
-//        ///if(strRes.isEmpty() || "" == strRes) return -1;// 涓虹┖浠h〃澶辫触
-//
-//        //涓嬮潰闇�姹傝皟鐢ㄦ枃浠剁殑鎺ュ彛锛岃皟鐢ㄦ垚鍔熻繑鍥炲悗锛屽緱鍒癴ilename鍜宖ileid 鐢ㄨ繖浜屼釜鍊煎幓鏇存柊鏁版嵁
-//
-//        String filePath = RuoYiConfig.getUploadPath();
-//        String strMutfileUrl = remShare.getAnnexbankcard();//鍙兘瀛樺湪澶氫釜鍦板潃锛屼互,鍒嗗紑
-//
-//        String strFUrl = "http://129.88.242.39:8899/seeyon/rest/attachment?token=" + strRes;
-//        //String strFUrl = "http://slb.hospitalstar.com:8899/seeyon/rest/attachment?token="+strRes;
-//        //strFUrl = String.format(strFUrl, strRes);
-//
-//        /*File test = null;
-//        File file = new File("E:\\YYJQ\\OPO\\WEB\\Upload\\upload\\2023\\02\\17");
-//        if (file.exists() && file.isDirectory()) {
-//            // 鑾峰彇鎵�鏈夌洸鐩掓枃浠跺す
-//            File[] ones = file.listFiles();
-//            for (File one : ones) {
-//                test = one;
-//            }
-//        }*/
-//
-//        String filename = "";
-//        String fileid = "";
-//
-//        String[] urlArray = strMutfileUrl.split(",");
-//        for (int i = 0; i < urlArray.length; i++) {
-//            String strOneFileName = urlArray[i];
-//            String strTemp = strOneFileName.substring(15);
-//            String strFile = filePath + strTemp;
-//            //FileUploadUtils.getAbsoluteFile(filePath,strOneFileName);
-//            String struploadResult = "";
-//            File filetest = new File(strFile);
-//            try {
-//                struploadResult = HttpClientKit.sendPostWithFile(filetest, strFUrl);
-//            } catch (Exception e) {
-//                e.printStackTrace();
-//            }
-//
-//
-//            //String strFRes = HttpClientKit.postMsg(strFUrl,jsonFObj);
-//            if (struploadResult == null) return 0;
-//            if (struploadResult.isEmpty()) return 0;
-//
-//            JSONObject jsonR = JSONObject.parseObject(struploadResult);
-//
-//            JSONArray jsonArr = jsonR.getJSONArray("atts");
-//            for (int j = 0; j < jsonArr.size(); j++) {
-//                JSONObject jsonRet = jsonArr.getJSONObject(j);
-//                String name1 = jsonRet.get("filename").toString();
-//                String id1 = jsonRet.get("fileUrl").toString();
-//                filename += name1;
-//                fileid += id1;
-//                if (i != urlArray.length - 1) {
-//                    filename += ",";
-//                    fileid += ",";
-//                }
-//            }
-//
-//        }
-//
-//        long nId = remShare.getId();
-//        remShare.setId(nId);
-//        remShare.setFilename(filename);
-//        remShare.setFileid(fileid);
-//        boolean bRet = fundServiceShare.updateById(remShare);
-//        if (!bRet) return -1;
-//
-//        return 0;
-//    }
+    /**
+     * fund琛ㄤ腑锛屼慨鏀筬undTaxId
+     */
+    @ApiOperation("fund琛ㄤ腑锛屼慨鏀筬undTaxId")
+    @PostMapping("/editFundTaxId")
+    public AjaxResult editFundTaxId(@RequestBody ServiceFund serviceFund) {
+        boolean b = serviceFundService.updateFundTaxIdById(serviceFund.getId(), serviceFund.getFundTaxId());
+        return AjaxResult.success(b);
+    }
 
     /**
      * 鏂板璐圭敤姹囨��
@@ -462,10 +284,11 @@
      * 瀹℃牳璐圭敤
      */
     @ApiOperation("瀹℃牳璐圭敤")
-    @Log(title = "瀹℃牳璐圭敤", businessType = BusinessType.OTHER)
+    @RepeatSubmit
+//    @Log(title = "瀹℃牳璐圭敤", businessType = BusinessType.OTHER)
     @PostMapping("/checkfund")
     public AjaxResult checkFund(@RequestBody CheckFundVO checkFundVO) {
-        logger.info("serviceFundController---checkFund鐨勫叆鍙傚�糲heckFundVO :{}", checkFundVO);
+        log.info("serviceFundController---checkFund鐨勫叆鍙傚�糲heckFundVO :{}", checkFundVO);
         ServiceFund serviceFund = serviceFundService.getById(checkFundVO.getFundid());
         if (serviceFund != null) {
             Integer TotalLevel = 0;
@@ -474,8 +297,7 @@
             serviceFundflowrule.setFundtype(2);
             serviceFundflowrule.setApplytype(serviceFund.getApplytype());
             serviceFundflowrule.setCheckuserno(loginUser.getUsername());
-            logger.info("serviceFundController---checkFund---queryList鐨勫叆鍙傚�約erviceFundflowrule:{}", serviceFundflowrule);
-
+            log.info("serviceFundController---checkFund---queryList鐨勫叆鍙傚�約erviceFundflowrule:{}", serviceFundflowrule);
             List<ServiceFundflowrule> serviceFundflowrules = serviceFundflowruleService.queryList(serviceFundflowrule);
 
             if (serviceFundflowrules == null || serviceFundflowrules.stream().count() == 0) {
@@ -506,6 +328,29 @@
                     }
                 }
                 FlowLevel = FlowLevel + 1;
+
+                if (serviceFund.getFlowlevel() == Long.valueOf(serviceFundflowrules.get(0).getFlowlevel() - 1) && serviceFund.getBackflowlevel() == 100) {
+                    log.info("璐㈠姟閫�鍥炲啀鎻愪氦锛屽嚭绾冲啀娆″鎵癸紝涔嬪悗鎻愪氦鍒拌储鍔�");
+                    //璇存槑鏄储鍔¢��鍥炲啀鎻愪氦鐨�.闇�瑕佸嚭绾冲啀鐪嬩竴閬嶏紝娌¢棶棰樹箣鍚庯紝寰�鍒嗕韩琛ㄩ噷鏂板
+//                    serviceFundService.addFundSharedInfo(serviceFund.getId());
+                    serviceFund.setFlowlevel(serviceFundflowrules.get(0).getTotallevel().longValue());
+                    serviceFund.setRecordstatus(99);
+                    serviceFund.setUploadStates(1);
+                    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 {
@@ -514,6 +359,8 @@
                     //搴斿尰闄㈣姹傚鏋滃嚭鐜伴��鍥烇紝鐩存帴閫�鍒板彂璧疯��
                     FlowLevel = 0;
                     RecordStatus = -1;
+                    logger.info("serviceFund杩涙潵浜嗗悧锛燂紵锛燂紵锛燂紵 :{},{}", RecordStatus, FlowLevel);
+                    System.out.println("serviceFund杩涙潵浜嗗悧锛燂紵锛燂紵锛燂紵");
                 } else {
                     RecordStatus = (FlowLevel + 1) * 2 - 1;
                     FlowLevel = (FlowLevel - 1);
@@ -521,6 +368,20 @@
                         FlowLevel = 0;
                     }
                 }
+
+                SysUser sysUser = sysUserService.selectUserByUserName(serviceFund.getUserno());
+                ArrayList<ConcurrentHashMap<String, Object>> contentList = new ArrayList<>();
+                ConcurrentHashMap map = new ConcurrentHashMap();
+                map.put("瀹℃壒浜猴細", loginUser.getUser().getUserName());
+                map.put("瀹℃壒鏃堕棿锛�", new Date());
+                map.put("鎰忚锛�", "涓嶉�氳繃");
+                if (StringUtils.isNotBlank(checkFundVO.getFlowcontent())) map.put("鎰忚锛�", checkFundVO.getFlowcontent());
+                contentList.add(map);
+                DingTalkReqVo dingTalkReqVo = new DingTalkReqVo();
+                dingTalkReqVo.setTitle("璐㈠姟绯荤粺椹冲洖淇℃伅");
+                dingTalkReqVo.setNumber(sysUser.getPhonenumber());
+                dingTalkReqVo.setContents(contentList);
+                dingTalkService.sendNotification(dingTalkReqVo);
             }
 
             serviceFund.setRecordstatus(RecordStatus);
@@ -541,14 +402,23 @@
                 serviceFundflow.setFlowcontent(checkFundVO.getFlowconclusion() == 1 ? "閫氳繃" : "涓嶉�氳繃");
             }
             serviceFundflow.setFlowlevel(OriginalFlowLevel + 1);
-            serviceFundflowService.save(serviceFundflow);
 
-            //001瀹℃壒閫氳繃涔嬪悗锛屽氨闇�瑕佹妸鈥滃姙鍏涓讳换鈥濈殑鍚嶅瓧濉笂
-            if (checkFundVO.getFlowconclusion() == 1 && user.getUserName().equals("001")) {
+            Boolean aBoolean = serviceFundflowService.saveData(serviceFundflow);
+            log.info("sserviceFund淇濆瓨鐨勭殑鍊兼槸-------- :{}", aBoolean);
+
+            //053瀹℃壒閫氳繃涔嬪悗锛屽氨闇�瑕佹妸鈥滃姙鍏涓讳换鈥濈殑鍚嶅瓧濉笂
+            if (checkFundVO.getFlowconclusion() == 1 && user.getUserName().equals("053")) {
                 serviceFund.setOfficedirector(user.getNickName());
+                serviceFund.setUploadStates(1);
             }
-            serviceFundService.updateById(serviceFund);
+            System.out.println("serviceFund鐨勫�兼槸--------:" + serviceFund);
+            log.info("寮�濮嬫洿鏂扮殑鐨勫�兼槸--------");
+//            ServiceFund updateServiceFund = new ServiceFund();
+//            updateServiceFund.setRecordstatus(serviceFund.getRecordstatus());
+//            updateServiceFund.setFlowlevel(serviceFund.getFlowlevel());
 
+            Boolean aBoolean1 = serviceFundService.updateById(serviceFund);
+            log.info("integer鏇存柊鐨勭殑鍊兼槸-------- :{}", aBoolean1);
             ServiceSystemmessage serviceSystemmessage = new ServiceSystemmessage();
             serviceSystemmessage.setFundtype(2);
             serviceSystemmessage.setApplytype(serviceFund.getApplytype());
@@ -556,24 +426,51 @@
             serviceSystemmessage.setSendusername(user.getNickName());
             serviceSystemmessage.setReceiveuserno(serviceFund.getUserno());
             serviceSystemmessage.setReceiveusername(serviceFund.getUsername());
+            serviceSystemmessage.setUpdateTime(new Date());
+            serviceSystemmessage.setUpdateBy(user.getNickName());
             serviceSystemmessage.setIsread(0);
             serviceSystemmessage.setMessagetype(1);
             serviceSystemmessage.setRelevantno(serviceFund.getId());
 
             if (CheckFlag == 1) {
-                //閫氳繃
-                serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁�氳繃");
-                serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勫叧浜庢崘鐚渚嬨��" + serviceFund.getDonorname() + "銆戠殑璐圭敤鐢宠宸查�氳繃" + (OriginalFlowLevel + 1) + "绾у鏍�");
-                if (TotalLevel == OriginalFlowLevel + 1) {
-                    serviceFundService.addFundSharedInfo(checkFundVO.getFundid());
-                }
 
+                //閫氳繃
+                if (serviceFund.getApplytype().equals("1")) {
+                    serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁�氳繃");
+                    serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勪笓瀹跺姵鍔¤垂鎹愮尞妗堜緥銆�" + serviceFund.getDonorname() + "銆戠殑璐圭敤鐢宠宸查�氳繃");
+                } else if (serviceFund.getApplytype().equals("2")) {
+                    serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁�氳繃");
+                    serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勪鸡鐞嗕笓瀹跺姵鍔¤垂鎹愮尞妗堜緥銆�" + serviceFund.getDonorname() + "銆戠殑璐圭敤鐢宠宸查�氳繃");
+                } else if (serviceFund.getApplytype().equals("3")) {
+                    serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁�氳繃");
+                    serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勫尰瀛︽垚鏈崘鐚渚嬨��" + serviceFund.getDonorname() + "銆戠殑璐圭敤鐢宠宸查�氳繃");
+                } else if (serviceFund.getApplytype().equals("4")) {
+                    serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁�氳繃");
+                    serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勫姙鍏垂鐢ㄧ敵璇峰凡閫氳繃");
+                } else if (serviceFund.getApplytype().equals("5")) {
+                    serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁�氳繃");
+                    serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勭哗鏁堢敵璇峰凡閫氳繃");
+                }
             } else {
                 //椹冲洖
-                serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁┏鍥�");
-                serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勫叧浜庢崘鐚渚嬨��" + serviceFund.getDonorname() + "銆戠殑璐圭敤鐢宠宸茶" + (OriginalFlowLevel + 1) + "绾у鏍搁┏鍥烇紝鍘熷洜涓�" + checkFundVO.getFlowcontent() + "");
+                if (serviceFund.getApplytype().equals("1")) {
+                    serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁┏鍥�");
+                    serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勪笓瀹跺姵鍔¤垂鎹愮尞妗堜緥銆�" + serviceFund.getDonorname() + "銆戠殑璐圭敤鐢宠宸茶椹冲洖锛屽師鍥�: " + checkFundVO.getFlowcontent() + "");
+                } else if (serviceFund.getApplytype().equals("2")) {
+                    serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁┏鍥�");
+                    serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勪鸡鐞嗕笓瀹跺姵鍔¤垂鎹愮尞妗堜緥銆�" + serviceFund.getDonorname() + "銆戠殑璐圭敤鐢宠宸茶椹冲洖锛屽師鍥�: " + checkFundVO.getFlowcontent() + "");
+                } else if (serviceFund.getApplytype().equals("3")) {
+                    serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁┏鍥�");
+                    serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勫尰瀛︽垚鏈崘鐚渚嬨��" + serviceFund.getDonorname() + "銆戠殑璐圭敤鐢宠宸茶椹冲洖锛屽師鍥�: " + checkFundVO.getFlowcontent() + "");
+                } else if (serviceFund.getApplytype().equals("4")) {
+                    serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁┏鍥�");
+                    serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勫姙鍏垂鐢ㄧ敵璇峰凡椹冲洖锛屽師鍥�: " + checkFundVO.getFlowcontent() + "");
+                } else if (serviceFund.getApplytype().equals("5")) {
+                    serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "绾у鏍搁┏鍥�");
+                    serviceSystemmessage.setMessagecontent("鎮�" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceFund.getCreateTime()) + "鎻愪氦鐨勭哗鏁堢敵璇峰凡椹冲洖锛屽師鍥�: " + checkFundVO.getFlowcontent() + "");
+                }
             }
-            ServiceSystemmessage.save(serviceSystemmessage);
+            iServiceSystemmessageService.save(serviceSystemmessage);
             return AjaxResult.success();
         } else {
             return AjaxResult.error(HttpStatus.NO_CONTENT, "璐圭敤缂栧彿涓嶆纭�");
@@ -588,37 +485,65 @@
     @Log(title = "璐圭敤涓婃姤", businessType = BusinessType.UPDATE)
     @PostMapping("/fundEdit")
     @RepeatSubmit
-    public AjaxResult fundEdit(@RequestBody ServiceFund serviceFund) {
+    public AjaxResult fundEdit(@RequestBody ServiceFundVO serviceFundVO) {
+        ServiceFund serviceFund = DtoConversionUtils.sourceToTarget(serviceFundVO, ServiceFund.class);
         log.info("淇敼璐圭敤鐢宠鍏ュ弬:{}", serviceFund);
         List<ServiceFund> infoByInfoIdList = serviceFundService.queryInfoById(serviceFund);
         log.info("淇敼璐圭敤鐢宠锛岄�氳繃鍏ュ弬鏌ヨ serviceFundService.queryInfoById鏁版嵁涓虹┖,鍏ュ弬:{}", infoByInfoIdList.size());
         if (CollectionUtils.isEmpty(infoByInfoIdList)) {
-            return toAjax(false);
+            Long id = serviceFundService.addOrUpdateNew(serviceFundVO);
+            serviceFund.setId(id);
         }
+
+        Long flowLavel = null;
+
+        LoginUser loginUser = getLoginUser();
+
+        //鏌ヨ蹇呭浜�
+        ServiceFundflowrule serviceFundflowrule = new ServiceFundflowrule();
+        serviceFundflowrule.setApplytype(serviceFund.getApplytype());
+        serviceFundflowrule.setMustAudite(1);
+        List<ServiceFundflowrule> serviceFundflowrules = serviceFundflowruleService.queryList(serviceFundflowrule);
+        log.info("fund蹇呭浜虹殑绛夌骇涓猴細{}", serviceFundflowrules.get(0).getFlowlevel());
+
         for (ServiceFund sf : infoByInfoIdList) {
+            sf.setApplyTime(new Date());
             //濡傛灉绛変簬100锛岃鏄庡凡缁忚蛋鍒板尰闄㈣储鍔¢偅杈逛簡锛涜储鍔¢偅杈瑰彇鏁版嵁鏄粠鍒嗕韩琛ㄥ彇锛屾墍浠ワ紝杩欓噷鐩存帴寰�鍒嗕韩琛ㄩ噷娣诲姞鏁版嵁灏辫浜�
             if (sf.getBackflowlevel() != null && sf.getBackflowlevel() == 199) {
                 //灏唂und琛ㄧ殑瀹℃牳鐘舵�佹敼鎴�100
                 sf.setBackflowlevel(100);
+
+                //閫�鍥炲啀鎻愪氦锛岄渶瑕佸啀鍒板嚭绾抽偅閲�
+                sf.setFlowlevel(Long.valueOf(serviceFundflowrules.get(0).getFlowlevel() - 1));
+                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(Long.valueOf(serviceFundflowrules.get(0).getFlowlevel() - 1));
+                sf.setRecordstatus(2);
+                serviceFundService.updateById(sf);
+            } else if (sf.getBackflowlevel() != null && sf.getBackflowlevel() >= serviceFundflowrules.get(0).getFlowlevel()) {
+                //鑱傜閫�鍥炵殑锛屼篃闇�瑕佸厛鍒板嚭绾抽偅閲�
+                sf.setFlowlevel(Long.valueOf(serviceFundflowrules.get(0).getFlowlevel() - 1));
+                sf.setRecordstatus(2);
+                serviceFundService.updateById(sf);
             } else {
 
                 Integer TotalLevel = 0;
-                LoginUser loginUser = getLoginUser();
-                SysUser user = loginUser.getUser();
                 List<Integer> postids = postService.selectPostListByUserId(loginUser.getUserId());
                 if (!postids.contains(2)) {
                     serviceFund.setRecordstatus(2);
                     if (serviceFund.getBackflowlevel() != null) {
                         serviceFund.setFlowlevel(serviceFund.getBackflowlevel().longValue());
                     } else {
-                        serviceFund.setBackflowlevel(1);
-                        serviceFund.setFlowlevel(1L);
+                        serviceFund.setBackflowlevel(serviceFundflowrules.get(0).getFlowlevel() - 1);
+                        serviceFund.setFlowlevel(Long.valueOf(serviceFundflowrules.get(0).getFlowlevel() - 1));
                     }
                 } else {
                     serviceFund.setRecordstatus(0);
@@ -641,11 +566,12 @@
         return toAjax(false);
     }
 
+
     /**
      * 鍒犻櫎璐圭敤鐢宠涓�
      */
     @ApiOperation("鍒犻櫎璐圭敤鐢宠涓�")
-    //@PreAuthorize("@ss.hasPermi('project:fund:remove')")
+    //// @PreAuthorize("@ss.hasPermi('project:fund:remove')")
     @Log(title = "璐圭敤鐢宠涓�", businessType = BusinessType.DELETE)
     @GetMapping("/remove/{ids}")
     public AjaxResult remove(@PathVariable Long[] ids) {
@@ -659,7 +585,7 @@
     @GetMapping(value = "/downloadLW/{id}")
     public Map downloadInfoLW(@PathVariable("id") Long id) throws IOException {
         Map dataMap = new HashMap();
-        getDataLW(dataMap, id);
+        String dataLW = getDataLW(dataMap, id);
         String filePath = getClass().getResource("/template/").getPath();
         System.out.println(filePath);
         //璁剧疆妯℃湰瑁呯疆鏂规硶鍜岃矾寰�,FreeMarker鏀寔澶氱妯℃澘瑁呰浇鏂规硶銆傚彲浠ラ噸servlet锛宑lasspath锛屾暟鎹簱鏁欑▼瑁呰浇锛�
@@ -673,7 +599,11 @@
             e.printStackTrace();
         }
         String newTime = String.valueOf(Calendar.getInstance().getTimeInMillis());
+
         String name = "涓撳鍔冲姟璐瑰彂鏀剧敵璇峰崟_" + dataMap.get("XM") + "_" + newTime;
+        if (dataLW.equals("4")) {
+            name = "鍔炲叕璐圭敤鐢宠鍗昣" + dataMap.get("XM") + "_" + newTime;
+        }
 
         //杈撳嚭鏂囨。璺緞鍙婂悕绉�
         File outFile = new File(RuoYiConfig.getProfile() + "/download/wordtemplate/" + name + ".doc");
@@ -692,10 +622,11 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
-    private void getDataLW(Map dataMap, Long id) {
+    private String getDataLW(Map dataMap, Long id) {
         ServiceFund serviceFund = serviceFundService.getById(id);
         if (serviceFund == null) {
             throw new ServiceException("涓嬭浇澶辫触锛岀敤鎴蜂俊鎭嚭閿�", HttpStatus.NO_CONTENT);
@@ -708,11 +639,15 @@
         dataMap.put("XZBH", serviceFund.getBh() == null ? "" : serviceFund.getBh());
         dataMap.put("ZB", serviceFund.getDeptmentname() == null ? "" : serviceFund.getDeptmentname());
         dataMap.put("TBYYMMDD", time);
-        dataMap.put("BXDFJ", serviceFund.getAttachcount() == 0 ? "   " : serviceFund.getAttachcount());
+        dataMap.put("BXDFJ", serviceFund.getAttachcount() == null ? "   " : serviceFund.getAttachcount());
         dataMap.put("JXZXM", serviceFund.getDonorname() == null ? "" : serviceFund.getDonorname());
         dataMap.put("JSR", serviceFund.getUsername() == null ? "" : serviceFund.getUsername());
 //        dataMap.put("FYXM1", "鏀粯涓撳璐圭敤锛屽叾涓◣鍓嶉噾棰�" + serviceFund.getPretaxcost() + "鍏冿紝绋庡悗閲戦" + serviceFund.getTaxedcost() + "鍏冦��");
-        dataMap.put("FYXM1", "浜轰綋鍣ㄥ畼鎹愮尞涓撳鍔冲姟璐�:" + serviceFund.getPretaxcost() + "鍏� (鍏朵腑绋庡悗璐圭敤鐢变腑蹇冩壙鎷呯◣璐�)銆�");
+        if (serviceFund.getApplytype().equals("1")) {
+            dataMap.put("FYXM1", "浜轰綋鍣ㄥ畼鎹愮尞涓撳鍔冲姟璐�:" + serviceFund.getPretaxcost() + "鍏� (鍏朵腑绋庡悗璐圭敤鐢变腑蹇冩壙鎷呯◣璐�)銆�");
+        } else if (serviceFund.getApplytype().equals("4")) {
+            dataMap.put("FYXM1", "鍔炲叕璐圭敤:" + serviceFund.getPretaxcost());
+        }
         dataMap.put("FYXM2", "");
         dataMap.put("FYXM3", "");
         dataMap.put("JEXS", serviceFund.getPretaxcost());
@@ -827,6 +762,7 @@
         dataMap.put("KSLJ", kslj);
         dataMap.put("SHLJ", shlj);
 
+        return serviceFund.getApplytype();
     }
 
 
@@ -967,11 +903,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);
         }
@@ -1014,14 +952,15 @@
     }
 
     /**
-     * 涓嬭浇鎹愮尞鑰呭尰瀛︽垚鏈粺璁¤〃
+     * 涓嬭浇鎹愮尞鑰呭尰瀛︺�佸姙鍏�佺哗鏁堟垚鏈粺璁¤〃
      */
-    @ApiOperation("鎹愮尞鑰呭尰瀛︽垚鏈粺璁¤〃")
+    @ApiOperation("鎹愮尞鑰呭尰瀛︺�佸姙鍏�佺哗鏁堟垚鏈粺璁¤〃")
     @GetMapping(value = "/downloadYX/{id}")
     public Map downloadInfoYX(@PathVariable("id") Long id) throws IOException {
         Map dataMap = new HashMap();
         String dataYX = getDataYX(dataMap, id);
         String filePath = getClass().getResource("/template/").getPath();
+        log.info("filePath鐨勫�间负:{}", filePath);
         System.out.println(filePath);
         //璁剧疆妯℃湰瑁呯疆鏂规硶鍜岃矾寰�,FreeMarker鏀寔澶氱妯℃澘瑁呰浇鏂规硶銆傚彲浠ラ噸servlet锛宑lasspath锛屾暟鎹簱鏁欑▼瑁呰浇锛�
         configuration.setDirectoryForTemplateLoading(new File(filePath));
@@ -1034,7 +973,7 @@
                 t = configuration.getTemplate("鍖诲鎴愭湰璐圭敤鐢宠鍗�.ftl");
             } else if (dataYX.equals("4")) {
                 t = configuration.getTemplate("鍔炲叕璐圭敤鐢宠鍗�.ftl");
-            }else if (dataYX.equals("5")) {
+            } else if (dataYX.equals("5")) {
                 t = configuration.getTemplate("缁╂晥璐圭敤鐢宠鍗�.ftl");
             }
         } catch (IOException e) {
@@ -1046,43 +985,62 @@
             name = "鍖诲鎴愭湰璐圭敤鐢宠鍗昣" + dataMap.get("XM") + "_" + newTime;
         } else if (dataYX.equals("4")) {
             name = "鍔炲叕璐圭敤鐢宠鍗昣" + dataMap.get("XM") + "_" + newTime;
+        } else if (dataYX.equals("5")) {
+            name = "缁╂晥璐圭敤鐢宠鍗昣" + dataMap.get("XM") + "_" + newTime;
         }
         //杈撳嚭鏂囨。璺緞鍙婂悕绉�
         File outFile = new File(RuoYiConfig.getProfile() + "/download/wordtemplate/" + name + ".doc");
         Writer out = null;
-
         try {
             out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile), "utf-8"));
 
         } catch (FileNotFoundException e1) {
-            e1.printStackTrace();
+            log.error("FileNotFoundException鎶ラ敊淇℃伅鏄細{}", e1.getMessage());
+//            e1.printStackTrace();
         }
         try {
+
             t.process(dataMap, out);
         } catch (TemplateException e) {
-            e.printStackTrace();
+            log.error("TemplateException鎶ラ敊淇¤嚜鏄細{}", e.getMessage());
+            e.getMessage();
         }
         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);
         }
         ServiceExternalperson infoByUserNo = null;
-        if (StringUtils.isNotBlank(serviceFund.getUserno())) {
+        if (StringUtils.isNotBlank(serviceFund.getUserno()) && serviceFund.getApplytype().equals("5")) {
             infoByUserNo = externalpersonService.getInfoByUserNo(serviceFund.getUserno());
         }
 
         List<ServiceFunddetail> fd = serviceFunddetailService.getAllDetailsByFDIDHZ(id);
+        if (serviceFund.getApplytype().equals("5")) {
+            //缁╂晥鐨勮鎯呭鏋滃皬浜�3琛岋紝榛樿瑕佺瓑浜�3琛�
+            if (fd.size() < 3) {
+                for (int i = 0; i <= 3 - fd.size(); i++) {
+                    ServiceFunddetail serviceFunddetail = new ServiceFunddetail();
+                    serviceFunddetail.setQuantity(0.00);
+                    serviceFunddetail.setPrice(0.00);
+                    serviceFunddetail.setAmount(0.00);
+                    fd.add(serviceFunddetail);
+                }
+            }
+        }
         if (fd == null) {
             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);
@@ -1099,48 +1057,75 @@
         dataMap.put("YWZ", serviceFund.getDeptmentname() == null ? "" : serviceFund.getDeptmentname());
         dataMap.put("ZHUZANG", serviceFund.getManagername() == null ? "" : serviceFund.getManagername());
 
+
+        if (StringUtils.isEmpty(serviceFund.getRemark())) {
+            dataMap.put("FYMC", LocalDate.now().getYear() + "骞�" + LocalDate.now().getMonthValue() + "鏈堜汉浣撳櫒瀹樿幏鍙栨湇鍔$鐞嗕腑蹇冨伐浣滀汉鍛樼哗鏁�");
+        } else {
+            dataMap.put("FYMC", serviceFund.getRemark().substring(0, serviceFund.getRemark().length() - 2) + "浜轰綋鍣ㄥ畼鑾峰彇鏈嶅姟绠$悊涓績宸ヤ綔浜哄憳缁╂晥");
+        }
         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 (StringUtils.isEmpty(serviceFund.getRemark())) {
+                fyxm += LocalDate.now().getYear() + "骞�" + LocalDate.now().getMonthValue() + "鏈堜汉浣撳櫒瀹樿幏鍙栨湇鍔$鐞嗕腑蹇冨伐浣滀汉鍛樼哗鏁�,鍏辫";
+            } else {
+                fyxm += serviceFund.getRemark().substring(0, serviceFund.getRemark().length() - 2) + "浜轰綋鍣ㄥ畼鑾峰彇鏈嶅姟绠$悊涓績宸ヤ綔浜哄憳缁╂晥,鍏辫";
+            }
+            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);
@@ -1160,7 +1145,7 @@
         dataMap.put("CWSH", serviceFund.getFinancechecher() == null ? "" : serviceFund.getFinancechecher());
 
         dataMap.put("YYMMDD", time);
-        dataMap.put("XM", serviceFund.getDonorname() == null ? "" : serviceFund.getDonorname());
+        dataMap.put("XM", serviceFund.getDonorname() == null ? "" : serviceFund.getDonorname().trim());
         dataMap.put("GZRY", serviceFund.getUsername() == null ? "" : serviceFund.getUsername());
         dataMap.put("ZZ", serviceFund.getManagername() == null ? "" : serviceFund.getManagername());
 
@@ -1245,6 +1230,7 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
@@ -1313,6 +1299,7 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
@@ -1812,6 +1799,7 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
@@ -1900,6 +1888,7 @@
         }
         Map<String, Object> map = new HashMap<>();
         map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc");
+        map.put("downloadName", name + ".doc");
         return map;
     }
 
@@ -1998,6 +1987,7 @@
     /**
      * 璐圭敤绫诲瀷璁℃暟
      */
+//    @NotRepeatCommit(key = "param:arg[1]", value = 30000)
     @ApiOperation("璐圭敤绫诲瀷璁℃暟")
     @GetMapping(value = "/countItem/{infoid}/{itemid}")
     public AjaxResult countItem(@PathVariable Long infoid, @PathVariable Long itemid) {
@@ -2019,4 +2009,44 @@
         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);
+    }
+
+    /**
+     * 瀵煎嚭涓撳鎶ラ攢璐圭敤姹囨��
+     */
+    @ApiOperation("瀵煎嚭涓撳鎶ラ攢璐圭敤姹囨��")
+    @Log(title = "璐圭敤鐢宠涓�", businessType = BusinessType.EXPORT)
+    @GetMapping("/exportFeeSum/{faxId}")
+    public Map<String, Object> exportFeeSum(@PathVariable Integer faxId) {
+        Map<String, Object> map = serviceFundService.exportFeeSum(faxId);
+        return map;
+    }
+
 }

--
Gitblit v1.9.3