package com.ruoyi.web.controller.project; 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; import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.core.domain.model.LoginUser; import com.ruoyi.common.core.page.TableDataInfo; import com.ruoyi.common.enums.BusinessType; import com.ruoyi.common.exception.ServiceException; import com.ruoyi.common.utils.SecurityUtils; import com.ruoyi.common.utils.bean.DtoConversionUtils; import com.ruoyi.common.utils.poi.ExcelUtil; import com.ruoyi.project.domain.*; import com.ruoyi.project.domain.dto.ServiceReimbursementDto; import com.ruoyi.project.domain.vo.CheckFundVO; import com.ruoyi.project.domain.vo.SpFinancialExpensesIn; import com.ruoyi.project.domain.vo.SpFinancialExpensesReimbursementOut; import com.ruoyi.project.service.*; import com.ruoyi.system.service.ISysPostService; import com.ruoyi.web.controller.enums.PersonType; import freemarker.template.Configuration; import freemarker.template.Template; import freemarker.template.TemplateException; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; import org.apache.ibatis.annotations.Options; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.util.CollectionUtils; import org.springframework.web.bind.annotation.*; import java.io.*; import java.math.BigDecimal; import java.text.SimpleDateFormat; import java.util.*; import java.util.regex.Pattern; import java.util.stream.Collectors; /** * 报销申请Controller * * @author ruoyi * @date 2022-01-24 */ @Slf4j @Api("报销申请") @RestController @RequestMapping("/project/reimbursement") public class ServiceReimbursementController extends BaseController { @Autowired private IServiceReimbursementService serviceReimbursementService; @Autowired private IServiceReimbursementSharedService serviceReimbursementSharedService; @Autowired private IServiceReimbursementpayeeService reimbursementpayeeService; @Autowired private IServiceReimbursementdetailService serviceReimbursementdetailService; @Autowired private IServiceFundflowruleService serviceFundflowruleService; @Autowired private IServiceFundflowService serviceFundflowService; @Autowired private IServiceFundService serviceFundService; @Autowired private IBaseOnlyvalueService baseOnlyvalueService; @Autowired private ISysPostService postService; @Autowired private IServiceSystemmessageService ServiceSystemmessage; private static Configuration configuration = null; public ServiceReimbursementController() { configuration = new Configuration(); configuration.setDefaultEncoding("utf-8"); } static String cashUnitLeft[] = {"元", "拾", "佰", "仟", "万", "拾", "佰", "仟", "亿", "拾", "佰", "仟", "万"}; static String cashUnitRight[] = {"角", "分", "厘"}; static String upperNumber[] = {"零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"}; /** * 查询报销申请列表 */ @ApiOperation("查询报销申请列表") //@PreAuthorize("@ss.hasPermi('project:reimbursement:list')") @Log(title = "查询报销申请列表", businessType = BusinessType.OTHER) @GetMapping("/list") public TableDataInfo list(ServiceReimbursement serviceReimbursement) { SysUser user = SecurityUtils.getLoginUser().getUser(); serviceReimbursement.setCreateBy(user.getUserName()); serviceReimbursement.setUsername(user.getNickName()); startPage(); List list = serviceReimbursementService.queryList(serviceReimbursement); return getDataTable(list); } /** * 根据日期查询报销申请列表 */ @ApiOperation("根据日期查询报销申请列表") @GetMapping("/listWithDate") public TableDataInfo listWithDate(ServiceReimbursementDto serviceReimbursementdto) { startPage(); List list = serviceReimbursementService.selectSearchList(serviceReimbursementdto); return getDataTable(list); } /** * 根据权限显示审核列表 */ @ApiOperation("根据权限显示审核列表") @Log(title = "根据权限显示审核列表", businessType = BusinessType.OTHER) @GetMapping("/listbypower") public TableDataInfo getListBypower(SpFinancialExpensesIn spFinancialExpensesIn) { LoginUser loginUser = getLoginUser(); String APPLICANT = spFinancialExpensesIn.getAPPLICANT(); String APPLICATIONBEGTIME = spFinancialExpensesIn.getAPPLICATIONBEGTIME(); String APPLICATIONENDTIME = spFinancialExpensesIn.getAPPLICATIONENDTIME(); Integer CHECKFLAG = spFinancialExpensesIn.getCHECKFLAG(); Integer APPLYTYPE = spFinancialExpensesIn.getAPPLYTYPE(); Integer checkstatus = spFinancialExpensesIn.getCheckstatus(); Integer pageNum = spFinancialExpensesIn.getPageNum(); Integer pageSize = spFinancialExpensesIn.getPageSize(); String donorname = spFinancialExpensesIn.getDonorname(); if (pageNum == null) { pageNum = 1; } if (pageSize == null) { pageSize = 10; } if (APPLICANT == null) { APPLICANT = ""; } if (APPLICATIONBEGTIME == null) { APPLICATIONBEGTIME = ""; } if (APPLICATIONENDTIME == null) { APPLICATIONENDTIME = ""; } //startPage(); List list = serviceReimbursementService.getListBypower(loginUser.getUsername(), 1, APPLICANT, APPLICATIONBEGTIME, APPLICATIONENDTIME, loginUser.getDeptId().toString(), CHECKFLAG, APPLYTYPE, checkstatus, donorname); //根据经办人筛选 if (StringUtils.isNotBlank(spFinancialExpensesIn.getUsername())) { list = list.stream().filter(reimbursementOut -> reimbursementOut.getUsername().contains(spFinancialExpensesIn.getUsername())).collect(Collectors.toList()); // 按name字段过滤 } //根据金额筛选 if (spFinancialExpensesIn.getMoney() != null) { list = list.stream().filter(reimbursementOut -> new BigDecimal(reimbursementOut.getAmountrequested()).compareTo(new BigDecimal(spFinancialExpensesIn.getMoney())) == 0).collect(Collectors.toList()); } //根据创建时间排序 Collections.sort(list, new Comparator() { @Override public int compare(SpFinancialExpensesReimbursementOut o1, SpFinancialExpensesReimbursementOut o2) { return o1.getCreateTime().compareTo(o2.getCreateTime()); } }); return getCustomDataTable(list, pageNum, pageSize); } /** * 导出报销申请列表 */ @ApiOperation("导出报销申请列表") //@PreAuthorize("@ss.hasPermi('project:reimbursement:export')") @Log(title = "报销申请", businessType = BusinessType.EXPORT) @GetMapping("/export") public AjaxResult export(ServiceReimbursement serviceReimbursement) { List list = serviceReimbursementService.queryList(serviceReimbursement); ExcelUtil util = new ExcelUtil(ServiceReimbursement.class); return util.exportExcel(list, "报销申请数据"); } /** * 获取报销申请详细信息 */ @ApiOperation("获取报销申请详细信息") //@PreAuthorize("@ss.hasPermi('project:reimbursement:query')") @GetMapping(value = "/{id}") public AjaxResult getInfo(@PathVariable("id") Long id) { return AjaxResult.success(serviceReimbursementService.getById(id)); } @GetMapping("/getMaxId") public AjaxResult getMaxId() { return AjaxResult.success(serviceReimbursementService.getMaxId()); } @GetMapping("/getRBDetailList/{id}") public AjaxResult getRBDetailList(@PathVariable("id") Long id) { return AjaxResult.success(serviceReimbursementService.getRBDetailList(id)); } /** * 新增报销申请 */ @ApiOperation("新增报销申请") //@PreAuthorize("@ss.hasPermi('project:reimbursement:add')") @Log(title = "报销申请", businessType = BusinessType.INSERT) @PostMapping @RepeatSubmit @Options(useGeneratedKeys = true, keyProperty = "id") public AjaxResult add(@RequestBody ServiceReimbursement serviceReimbursement) { if (!Objects.isNull(serviceReimbursement)) { serviceReimbursement.setCreateTime(new Date()); serviceReimbursement.setCheckstatus(serviceReimbursement.getCheckstatus() == null ? 1 : serviceReimbursement.getCheckstatus()); boolean b = serviceReimbursementService.save(serviceReimbursement); Long id = serviceReimbursement.getId(); return AjaxResult.success(id); } return error(); } /** * 差旅费上报 */ @ApiOperation("差旅费上报") @Log(title = "差旅费上报", businessType = BusinessType.OTHER) @PostMapping("/travelexpensereport") public AjaxResult travelexpensereport(@RequestBody CheckFundVO checkFundVO) { ServiceReimbursement serviceReimbursement = serviceReimbursementService.getById(checkFundVO.getFundid()); serviceReimbursement.setApplyTime(new Date()); //如果等于100,说明已经走到医院财务那边了;财务那边取数据是从分享表取,所以,这里直接往分享表里添加数据就行了; if (!Objects.isNull(serviceReimbursement) && serviceReimbursement.getBackflowlevel() != null) { if (serviceReimbursement.getBackflowlevel() == 100 || serviceReimbursement.getBackflowlevel() == 199) { // if (serviceReimbursement.getBackflowlevel() == 199) { //将退回阶段设置成100 serviceReimbursement.setBackflowlevel(100L); //退回再提交,需要再到出纳那里 serviceReimbursement.setFlowlevel(1L); serviceReimbursement.setRecordstatus(2); serviceReimbursementService.updateById(serviceReimbursement); //将修改的上报数据 新增一条 // serviceReimbursementService.addSharedData(checkFundVO.getFundid()); return success(); } else if (serviceReimbursement.getBackflowlevel() == 2) { //聂科退回的,也需要走出纳那里 serviceReimbursement.setFlowlevel(1L); serviceReimbursement.setRecordstatus(2); serviceReimbursementService.updateById(serviceReimbursement); return success(); } } if (serviceReimbursement != null) { Integer TotalLevel = 0; LoginUser loginUser = getLoginUser(); SysUser user = loginUser.getUser(); List postids = postService.selectPostListByUserId(loginUser.getUserId()); if (!postids.contains(2)) { serviceReimbursement.setRecordstatus(2); if (serviceReimbursement.getBackflowlevel() != null) { serviceReimbursement.setFlowlevel(serviceReimbursement.getBackflowlevel()); } else { serviceReimbursement.setBackflowlevel(1L); serviceReimbursement.setFlowlevel(1L); } } else { serviceReimbursement.setRecordstatus(0); if (serviceReimbursement.getBackflowlevel() != null) { serviceReimbursement.setFlowlevel(serviceReimbursement.getBackflowlevel()); } else { serviceReimbursement.setFlowlevel(0L); serviceReimbursement.setBackflowlevel(0L); } } if (!postids.contains(2) && (serviceReimbursement.getBackflowlevel() == null || serviceReimbursement.getBackflowlevel() == 0)) { ServiceFundflow serviceFundflow = new ServiceFundflow(); serviceFundflow.setFundid(serviceReimbursement.getId()); serviceFundflow.setCheckuserno(user.getUserName()); serviceFundflow.setCheckusername(user.getNickName()); serviceFundflow.setFundtype(1); serviceFundflow.setApplytype("0"); serviceFundflow.setFlowconclusion(1); serviceFundflow.setFlowcontent("非专职人员直接进入二级审核"); serviceFundflow.setFlowlevel(1); serviceFundflowService.save(serviceFundflow); } serviceReimbursementService.updateById(serviceReimbursement); return AjaxResult.success(); } else { return AjaxResult.error(HttpStatus.NO_CONTENT, "费用编号不正确"); } } /** * 审核费用 */ @ApiOperation("审核费用") @Log(title = "审核费用", businessType = BusinessType.OTHER) @PostMapping("/checkfund") public AjaxResult checkFund(@RequestBody CheckFundVO checkFundVO) { log.info("审核费用的入参 : {}", checkFundVO); ServiceReimbursement serviceReimbursement = serviceReimbursementService.getById(checkFundVO.getFundid()); log.info("审核费用的serviceReimbursementService.getById返参 : {}", serviceReimbursement); if (serviceReimbursement != null) { Integer totalLevel = 0; LoginUser loginUser = getLoginUser(); ServiceFundflowrule serviceFundflowrule = new ServiceFundflowrule(); serviceFundflowrule.setFundtype(1); serviceFundflowrule.setApplytype("0"); serviceFundflowrule.setCheckuserno(loginUser.getUsername()); List serviceFundflowrules = serviceFundflowruleService.queryList(serviceFundflowrule); log.info("审核费用的serviceFundflowruleService.queryList返参 : {}", serviceFundflowrules.size()); if (serviceFundflowrules == null || serviceFundflowrules.stream().count() == 0) { return AjaxResult.error(HttpStatus.ERROR, "当前人员无此记录审核权限"); } if (serviceFundflowrules.get(0).getFlowlevel() - 1 != serviceReimbursement.getFlowlevel()) { return AjaxResult.error(HttpStatus.ERROR, "当前人员与此记录的审核级别不符"); } if (serviceFundflowrules != null && serviceFundflowrules.stream().count() > 0) { totalLevel = serviceFundflowrules.get(0).getTotallevel(); } Integer CheckFlag = 0; Integer RecordStatus = serviceReimbursement.getRecordstatus(); Integer FlowLevel = Integer.valueOf(serviceReimbursement.getFlowlevel().toString()); if (Objects.isNull(serviceReimbursement.getBackflowlevel()) && !Objects.isNull(serviceReimbursement.getFlowlevel())) { serviceReimbursement.setBackflowlevel(Long.valueOf(FlowLevel.toString())); } Integer OriginalFlowLevel = FlowLevel; if (checkFundVO.getFlowconclusion() == 1) { CheckFlag = 1; if (totalLevel == 0) { //99 取消 RecordStatus = 99; } else { if (totalLevel == FlowLevel + 1) { RecordStatus = 99; } else { RecordStatus = (FlowLevel + 1) * 2; } } if (serviceReimbursement.getFlowlevel() == 1 && serviceReimbursement.getBackflowlevel() == 100) { log.info("出差补贴被 财务退回再提交,出纳再次审批,之后提交到财务:{}", serviceReimbursement.getId()); //说明是财务退回再提交的.需要出纳再看一遍,没问题之后,往分享表里新增 serviceReimbursementService.addSharedData(serviceReimbursement.getId()); serviceReimbursement.setFlowlevel(100L); serviceReimbursement.setRecordstatus(99); boolean b = serviceReimbursementService.updateById(serviceReimbursement); log.info("是否修改成功:{}", b); //保存审批流程表 ServiceFundflow serviceFundflow = new ServiceFundflow(); SysUser user = loginUser.getUser(); serviceFundflow.setFundid(serviceReimbursement.getId()); serviceFundflow.setCheckuserno(user.getUserName()); serviceFundflow.setCheckusername(user.getNickName()); serviceFundflow.setFundtype(1); serviceFundflow.setApplytype("0"); serviceFundflow.setFlowconclusion(CheckFlag); serviceFundflow.setFlowcontent("通过"); serviceFundflow.setFlowlevel(OriginalFlowLevel + 1); Boolean aBoolean = serviceFundflowService.save(serviceFundflow); return AjaxResult.success(); } FlowLevel = FlowLevel + 1; serviceReimbursement.setBackflowlevel(Long.valueOf(FlowLevel)); } else { CheckFlag = 2; if (CheckFlag == 2) { //应医院要求如果出现退回,直接退到发起者 FlowLevel = 0; RecordStatus = -1; } else { //下面是原来的写法,一级一级的往下退,医院现在不要这样搞了,下面这段代码先保留,等医院回心转意,再给放开 RecordStatus = (FlowLevel + 1) * 2 - 1; FlowLevel = (FlowLevel - 1); if (FlowLevel < 0) { FlowLevel = 0; } } } serviceReimbursement.setRecordstatus(RecordStatus); serviceReimbursement.setFlowlevel(Long.valueOf(FlowLevel.toString())); ServiceFundflow serviceFundflow = new ServiceFundflow(); SysUser user = loginUser.getUser(); serviceFundflow.setFundid(serviceReimbursement.getId()); serviceFundflow.setCheckuserno(user.getUserName()); serviceFundflow.setCheckusername(user.getNickName()); serviceFundflow.setFundtype(1); serviceFundflow.setApplytype("0"); serviceFundflow.setFlowconclusion(CheckFlag); if (StringUtils.isNotBlank(checkFundVO.getFlowcontent())) { serviceFundflow.setFlowcontent(checkFundVO.getFlowcontent()); } else { serviceFundflow.setFlowcontent(checkFundVO.getFlowconclusion() == 1 ? "通过" : "不通过"); } serviceFundflow.setFlowlevel(OriginalFlowLevel + 1); serviceFundflowService.save(serviceFundflow); List postids = postService.selectPostListByUserId(loginUser.getUserId()); log.info("postService.selectPostListByUserId : {}", postids.size()); if (!postids.contains(2) && !postids.contains(6) && (serviceReimbursement.getBackflowlevel() == null || serviceReimbursement.getBackflowlevel() == 0)) { if (CheckFlag == 2 && OriginalFlowLevel == 1) { ServiceFundflow serviceFundflowAuto = new ServiceFundflow(); serviceFundflowAuto.setFundid(serviceReimbursement.getId()); serviceFundflowAuto.setCheckuserno(user.getUserName()); serviceFundflowAuto.setCheckusername(user.getNickName()); serviceFundflowAuto.setFundtype(1); serviceFundflowAuto.setApplytype("0"); serviceFundflowAuto.setFlowconclusion(CheckFlag); serviceFundflowAuto.setFlowcontent("非专职人员二级审核拒绝后直接退回到修改状态"); serviceFundflowAuto.setFlowlevel(1); serviceFundflowService.save(serviceFundflowAuto); serviceReimbursement.setRecordstatus(1); } } //001审批通过之后,就需要把“办公室主任”的名字填上 if (checkFundVO.getFlowconclusion() == 1 && user.getUserName().equals("001")) { serviceReimbursement.setOfficedirector(user.getNickName()); } serviceReimbursementService.updateById(serviceReimbursement); ServiceSystemmessage serviceSystemmessage = new ServiceSystemmessage(); serviceSystemmessage.setFundtype(1); serviceSystemmessage.setApplytype("0"); serviceSystemmessage.setSenduserno(user.getUserName()); serviceSystemmessage.setSendusername(user.getNickName()); serviceSystemmessage.setReceiveuserno(serviceReimbursement.getUserno()); serviceSystemmessage.setReceiveusername(serviceReimbursement.getUsername()); serviceSystemmessage.setIsread(0); serviceSystemmessage.setMessagetype(1); serviceSystemmessage.setRelevantno(serviceReimbursement.getId()); log.info("CheckFlag的值 : {}", CheckFlag); if (CheckFlag == 1) { //通过 serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "级审核通过"); serviceSystemmessage.setMessagecontent("您" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceReimbursement.getCreateTime()) + "提交的关于捐献案例【" + serviceReimbursement.getDonorname() + "】的差旅费申请已通过" + (OriginalFlowLevel + 1) + "级审核"); log.info("totalLevel的值 : {}, OriginalFlowLevel的值:{}", totalLevel, OriginalFlowLevel); if (totalLevel == OriginalFlowLevel + 1) { //所有数据新增到备份表 serviceReimbursementService.addSharedData(checkFundVO.getFundid()); } } else { //驳回 serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "级审核驳回"); serviceSystemmessage.setMessagecontent("您" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceReimbursement.getCreateTime()) + "提交的关于捐献案例【" + serviceReimbursement.getDonorname() + "】的差旅费申请已被" + (OriginalFlowLevel + 1) + "级审核驳回,原因为" + checkFundVO.getFlowcontent() + ""); } ServiceSystemmessage.save(serviceSystemmessage); return AjaxResult.success(); } else { return AjaxResult.error(HttpStatus.NO_CONTENT, "费用编号不正确"); } } /** * 修改报销申请 */ @ApiOperation("修改报销申请") //@PreAuthorize("@ss.hasPermi('project:reimbursement:edit')") @Log(title = "报销申请", businessType = BusinessType.UPDATE) @PostMapping("/reimbursementEdit") @RepeatSubmit public AjaxResult edit(@RequestBody ServiceReimbursement serviceReimbursement) { boolean b = serviceReimbursementService.updateById(serviceReimbursement); // if (b) { // addReiSharedDatd(serviceReimbursement, 2); // } return toAjax(b); } /** * 修改报销申请 */ @ApiOperation("修改报销申请") //@PreAuthorize("@ss.hasPermi('project:reimbursement:edit')") @Log(title = "审核费用", businessType = BusinessType.OTHER) @PostMapping("/editMoney") public AjaxResult editMoney(@RequestBody List serviceReimbursement) { boolean b = serviceReimbursementService.updateById(null); // if (b) { // addReiSharedDatd(null, 2); // } return toAjax(b); } /** * 删除报销申请 */ @ApiOperation("删除报销申请") //@PreAuthorize("@ss.hasPermi('project:reimbursement:remove')") @Log(title = "报销申请") @GetMapping("/remove/{ids}") public AjaxResult remove(@PathVariable Long[] ids) { return toAjax(serviceReimbursementService.removeByIds(Arrays.asList(ids))); } /** * 下载工作人员差旅费报销单 */ @ApiOperation("差旅费报销申请单") @GetMapping(value = "/download/{id}") public Map downloadInfo(@PathVariable("id") Long id) throws IOException { Map dataMap = new HashMap(); getData(dataMap, id); String filePath = getClass().getResource("/template/").getPath(); log.info("下载地址是啥???{}", filePath); System.out.println(filePath); //设置模本装置方法和路径,FreeMarker支持多种模板装载方法。可以重servlet,classpath,数据库教程装载, configuration.setDirectoryForTemplateLoading(new File(filePath)); Template t = null; try { //捐献表.ftl为要装载的模板 t = configuration.getTemplate("差旅费报销申请单.ftl"); } catch (IOException e) { e.printStackTrace(); } String newTime = String.valueOf(Calendar.getInstance().getTimeInMillis()); String name = "差旅费报销申请单_" + dataMap.get("JSR") + "_" + newTime; //输出文档路径及名称 File outFile = new File(RuoYiConfig.getProfile() + "/download/wordtemplate/" + name + ".doc"); //创建文件夹 File folderPath = new File(RuoYiConfig.getProfile() + "/download/wordtemplate"); if (!folderPath.exists()) { boolean success = folderPath.mkdirs(); if (success) { System.out.println("目录创建成功"); } else { System.out.println("目录创建失败"); } } else { System.out.println("目录已存在"); } Writer out = null; try { out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile), "utf-8")); } catch (FileNotFoundException e1) { e1.printStackTrace(); } try { t.process(dataMap, out); } catch (TemplateException e) { e.printStackTrace(); } Map map = new HashMap<>(); map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc"); map.put("downloadName", name + ".doc"); return map; } private void getData(Map dataMap, Long id) { //ServiceReimbursement serviceReimbursement = serviceReimbursementService.getById(id); ServiceReimbursement serviceReimbursement = null; ServiceReimbursementEo serviceReimbursementEo = new ServiceReimbursementEo(); serviceReimbursementEo.setId(id); List rdInfoByItem = serviceReimbursementService.getRDInfoByItem(serviceReimbursementEo); log.info("rdInfoByItem是否为空 :{}", CollectionUtils.isEmpty(rdInfoByItem) ? null : rdInfoByItem.size()); for (int i = 0; i < rdInfoByItem.size(); i++) { ServiceReimbursementEo serviceReimbursementEo1 = rdInfoByItem.get(i); String codeByInfo = PersonType.getCodeByInfo(serviceReimbursementEo1.getPersontype()); serviceReimbursementEo1.setPersontype(codeByInfo); } //获取报销支付信息 List reimbursementpayeeInfo = reimbursementpayeeService.getReimbursementpayeeInfo(serviceReimbursementEo); log.info("reimbursementpayeeInfo是否为空 :{}", CollectionUtils.isEmpty(reimbursementpayeeInfo) ? null : reimbursementpayeeInfo.size()); Map> listMap = rdInfoByItem.stream().collect(Collectors.groupingBy(ServiceReimbursementEo::getPersontype)); List> list = new ArrayList<>(); StringBuffer FYXM1 = new StringBuffer(); StringBuffer FYXM2 = new StringBuffer(); StringBuffer FYXM3 = new StringBuffer(); int flag = 0; String key1 = null; BigDecimal allMoney = new BigDecimal(0.00); BigDecimal otherMoneyall = new BigDecimal(0.00); for (String key : listMap.keySet()) { Map map = new HashMap<>(); List values = listMap.get(key); BigDecimal otherMoney = new BigDecimal(0.00); BigDecimal keyOneMoney = new BigDecimal(0.00); BigDecimal keyTwoMoney = new BigDecimal(0.00); for (ServiceReimbursementEo serviceReimbursementEo1 : values) { otherMoney = otherMoney.add(serviceReimbursementEo1.getTrafficexpense()).add(serviceReimbursementEo1.getHotelexpense()).add(serviceReimbursementEo1.getCityfee()).add(serviceReimbursementEo1.getFoodexpenses()).add(serviceReimbursementEo1.getFoodallowance()).add(serviceReimbursementEo1.getOtherexpense()).add(serviceReimbursementEo1.getOtherfeeamount()); } map.put(key, otherMoney); list.add(map); // 不为专家或家属,key有可能是数字,有可能是汉字 Pattern pattern = Pattern.compile("^[-\\+]?[\\d]*$"); boolean matches = pattern.matcher(key).matches(); if (matches) { if (!key.equals("3") && !key.equals("4")) { //将上一次的清空 FYXM1.delete(0, FYXM1.length()); //再新增 otherMoneyall = otherMoneyall.add(otherMoney); FYXM1.append("OP0 工作人员报销差旅费" + ":" + otherMoneyall + " "); } else { if (flag == 0) { key1 = key; flag = 1; } if (key1 == key) { if (key.equals("3")) { // FYXM2.append(PersonType.getInfoByCode(key) + ":" + otherMoney); FYXM2.append("专家报销差旅费 :" + otherMoney); allMoney = allMoney.add(otherMoney); } else { FYXM2.append("家属报销差旅费及误工费用 : " + otherMoney); allMoney = allMoney.add(otherMoney); } } else { if (key.equals("3")) { // FYXM2.append(PersonType.getInfoByCode(key) + ":" + otherMoney); FYXM3.append("专家报销差旅费 :" + otherMoney); allMoney = allMoney.add(otherMoney); } else { FYXM3.append("家属报销差旅费及误工费用 : " + otherMoney); allMoney = allMoney.add(otherMoney); } } } } else { if (!key.equals("专家") && !key.equals("家属")) { //将上一次的清空 FYXM1.delete(0, FYXM1.length()); //再新增 otherMoneyall = otherMoneyall.add(otherMoney); FYXM1.append("OP0 工作人员报销差旅费" + ":" + otherMoneyall + " "); } else { if (flag == 0) { key1 = key; flag = 1; } if (key1 == key) { if (key.equals("专家")) { // FYXM2.append(PersonType.getInfoByCode(key) + ":" + otherMoney); FYXM2.append("专家报销差旅费 :" + otherMoney); allMoney = allMoney.add(otherMoney); } else { FYXM2.append("家属报销差旅费及误工费用 : " + otherMoney); allMoney = allMoney.add(otherMoney); } } else { if (key.equals("专家")) { // FYXM2.append(PersonType.getInfoByCode(key) + ":" + otherMoney); FYXM3.append("专家报销差旅费 :" + otherMoney); allMoney = allMoney.add(otherMoney); } else { FYXM3.append("家属报销差旅费及误工费用 : " + otherMoney); allMoney = allMoney.add(otherMoney); } } } } } allMoney = allMoney.add(otherMoneyall); if (FYXM1.length() == 0) { if (FYXM2.length() != 0 && FYXM3.length() != 0) { FYXM1.append(FYXM3); FYXM3.setLength(0); } else if (FYXM2.length() != 0 && FYXM3.length() == 0) { FYXM1.append(FYXM2); FYXM2.setLength(0); } } else if (FYXM2.length() == 0) { if (FYXM3.length() != 0) { FYXM2.append(FYXM3); FYXM3.setLength(0); } } if (rdInfoByItem == null || rdInfoByItem.size() == 0) { throw new ServiceException("下载失败,用户信息出错", HttpStatus.NO_CONTENT); } Date dt = rdInfoByItem.get(0).getCreateTime(); SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String date = formatter.format(dt); String time = date.substring(0, 10); dataMap.put("ZB", rdInfoByItem.get(0).getDeptmentname() == null ? "" : rdInfoByItem.get(0).getDeptmentname()); dataMap.put("XZBH", rdInfoByItem.get(0).getBh() == null ? "" : rdInfoByItem.get(0).getBh()); dataMap.put("TBYYMMDD", time); dataMap.put("BXDFJ", rdInfoByItem.get(0).getAttachcount() == null ? " " : "" + rdInfoByItem.get(0).getAttachcount()); dataMap.put("JXZXM", rdInfoByItem.get(0).getDonorname() == null ? "" : rdInfoByItem.get(0).getDonorname()); dataMap.put("JSR", rdInfoByItem.get(0).getUsername() == null ? "" : rdInfoByItem.get(0).getUsername()); if (FYXM1.length() != 0) { dataMap.put("FYXM1", FYXM1.toString() + "元 "); } else { dataMap.put("FYXM1", ""); } if (FYXM2.length() != 0) { dataMap.put("FYXM2", FYXM2.toString() + "元 "); } else { dataMap.put("FYXM2", ""); } if (FYXM3.length() != 0) { dataMap.put("FYXM3", FYXM3.toString() + "元 "); } else { dataMap.put("FYXM3", ""); } dataMap.put("JEXS", allMoney); dataMap.put("JEDS", convert(allMoney.doubleValue()) + "整"); String remark = ""; for (ServiceReimbursementpayee serviceReimbursementpayee : reimbursementpayeeInfo) { remark += " " + serviceReimbursementpayee.getPersonname() + " " + serviceReimbursementpayee.getAmount(); remark += " 元; "; if (!StringUtils.isEmpty(serviceReimbursementpayee.getBankname())) { remark += serviceReimbursementpayee.getBankname() + " ( " + serviceReimbursementpayee.getBankcardno() + ")"; } remark += " 备注: " + serviceReimbursementpayee.getPersontype(); if (!StringUtils.isEmpty(serviceReimbursementpayee.getRemark())) { remark += serviceReimbursementpayee.getRemark(); } } dataMap.put("BXBZ", remark); dataMap.put("ZXFZR", StringUtils.isEmpty(rdInfoByItem.get(0).getOpochecker()) ? "" : rdInfoByItem.get(0).getOpochecker()); // dataMap.put("CWFYZ", StringUtils.isEmpty(rdInfoByItem.get(0).getFinvicepresident()) ? "" : rdInfoByItem.get(0).getFinvicepresident()); dataMap.put("YWFYZ", StringUtils.isEmpty(rdInfoByItem.get(0).getBusvicepresident()) ? "" : rdInfoByItem.get(0).getBusvicepresident()); dataMap.put("BGSZR", StringUtils.isEmpty(rdInfoByItem.get(0).getOfficedirector()) ? "" : rdInfoByItem.get(0).getOfficedirector()); dataMap.put("CWBZR", StringUtils.isEmpty(rdInfoByItem.get(0).getFinancedirector()) ? "" : rdInfoByItem.get(0).getFinancedirector()); dataMap.put("CWSH", StringUtils.isEmpty(rdInfoByItem.get(0).getFinancechecher()) ? "" : rdInfoByItem.get(0).getFinancechecher()); dataMap.put("YYMMDD", time); dataMap.put("FJ", rdInfoByItem.get(0).getAttachcount() == null ? " " : "" + rdInfoByItem.get(0).getAttachcount()); dataMap.put("FP", rdInfoByItem.get(0).getInvoicecount() == null ? " " : "" + rdInfoByItem.get(0).getInvoicecount()); dataMap.put("XM", rdInfoByItem.get(0).getTravelers() == null ? "" : rdInfoByItem.get(0).getTravelers()); dataMap.put("BXR", rdInfoByItem.get(0).getUsername() == null ? "" : rdInfoByItem.get(0).getUsername()); dataMap.put("QYZZ", rdInfoByItem.get(0).getManagername() == null ? "" : rdInfoByItem.get(0).getManagername()); dataMap.put("CCSY", rdInfoByItem.get(0).getReason() == null ? "" : rdInfoByItem.get(0).getReason()); List rd = serviceReimbursementdetailService.getAllDetailsByRBID(id); if (rd == null) { throw new ServiceException("下载失败,没有对应信息", HttpStatus.NO_CONTENT); } List> newsList = new ArrayList>(); int days = 0; BigDecimal te = BigDecimal.ZERO; BigDecimal cf = BigDecimal.ZERO; BigDecimal he = BigDecimal.ZERO; BigDecimal oe = BigDecimal.ZERO; BigDecimal fe = BigDecimal.ZERO; BigDecimal fa = BigDecimal.ZERO; BigDecimal hj = BigDecimal.ZERO; BigDecimal qt = BigDecimal.ZERO; for (ServiceReimbursementdetail s : rd) { Map map = new HashMap(); Date st = s.getStarttime(); SimpleDateFormat formatter_st = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String date_st = formatter_st.format(st); String year_st = date_st.substring(0, 4); String month_st = date_st.substring(5, 7); String day_st = date_st.substring(8, 10); map.put("DY", year_st == null ? "" : year_st); map.put("DM", month_st == null ? "" : month_st); map.put("DDD", day_st == null ? "" : day_st); map.put("DA", s.getDeparture() == null ? "" : s.getDeparture()); Date et = s.getEndtime(); String year_et = null; String month_et = null; String day_et = null; if (et != null) { SimpleDateFormat formatter_et = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); String date_et = formatter_et.format(et); year_et = date_et.substring(0, 4); month_et = date_et.substring(5, 7); day_et = date_et.substring(8, 10); } map.put("AY", year_et == null ? "" : year_et); map.put("AM", month_et == null ? "" : month_et); map.put("AD", day_et == null ? "" : day_et); map.put("AA", s.getDestination() == null ? "" : s.getDestination()); map.put("ND", s.getDays() == 0 ? "" : s.getDays() + ""); days += s.getDays(); map.put("JT", s.getTraffictype() == null ? "" : s.getTraffictype()); map.put("QTFSM", s.getOtherfeedesc() == null ? "" : s.getOtherfeedesc()); map.put("JTF", s.getTrafficexpense().equals(BigDecimal.ZERO) ? "" : String.format("%.2f", s.getTrafficexpense()).toString() + ""); te = te.add(s.getTrafficexpense()); map.put("SNJT", s.getCityfee().equals(BigDecimal.ZERO) ? "" : String.format("%.2f", s.getCityfee()).toString() + ""); cf = cf.add(s.getCityfee()); map.put("ZSF", s.getHotelexpense().equals(BigDecimal.ZERO) ? "" : String.format("%.2f", s.getHotelexpense()).toString() + ""); he = he.add(s.getHotelexpense()); map.put("ZF", s.getOtherexpense().equals(BigDecimal.ZERO) ? "" : String.format("%.2f", s.getOtherexpense()).toString() + ""); oe = oe.add(s.getOtherexpense()); map.put("HSBX", s.getFoodexpenses().equals(BigDecimal.ZERO) ? "" : String.format("%.2f", s.getFoodexpenses()).toString() + ""); fe = fe.add(s.getFoodexpenses()); map.put("HSBZ", s.getFoodallowance().equals(BigDecimal.ZERO) ? "" : String.format("%.2f", s.getFoodallowance()).toString() + ""); fa = fa.add(s.getFoodallowance()); map.put("QTF", s.getOtherfeeamount().equals(BigDecimal.ZERO) ? "" : String.format("%.2f", s.getOtherfeeamount()).toString() + ""); qt = qt.add(s.getOtherfeeamount()); map.put("HJ", String.format("%.2f", s.getTrafficexpense().add(s.getCityfee()).add(s.getHotelexpense()).add(s.getOtherexpense()).add(s.getFoodexpenses()).add(s.getFoodallowance()).add(s.getOtherfeeamount())).toString() + ""); hj = hj.add(s.getTrafficexpense().add(s.getCityfee()).add(s.getHotelexpense()).add(s.getOtherexpense()).add(s.getFoodexpenses()).add(s.getFoodallowance()).add(s.getOtherfeeamount())); //hj = Math.round(hj * 100) * 0.01d; // DecimalFormat df = new DecimalFormat("0.00"); // hj = new Double(df.format(hj).toString()); newsList.add(map); } dataMap.put("list", newsList); dataMap.put("TND", "" + days); dataMap.put("TJT", ""); dataMap.put("TJTF", "" + String.format("%.2f", te).toString() + ""); dataMap.put("TSNJT", "" + String.format("%.2f", cf).toString() + ""); dataMap.put("TZSF", "" + String.format("%.2f", he).toString() + ""); dataMap.put("TZF", "" + String.format("%.2f", oe).toString() + ""); dataMap.put("THSBX", "" + String.format("%.2f", fe).toString() + ""); dataMap.put("THSBZ", "" + String.format("%.2f", fa).toString() + ""); dataMap.put("TQTF", "" + String.format("%.2f", qt).toString() + ""); dataMap.put("THJ", "" + String.format("%.2f", hj).toString() + ""); dataMap.put("DS", convert(hj.doubleValue()) + "整"); //dataMap.put("DS", "整"); dataMap.put("XS", String.format("%.2f", hj).toString() + ""); dataMap.put("R", StringUtils.isEmpty(rdInfoByItem.get(0).getCosttypename()) ? "" : rdInfoByItem.get(0).getCosttypename()); } public static String convert(Double money) { String smoney = money.toString(); try { if (smoney.indexOf(".") != -1) { //把数值分为整数型和带小数的数值分开处理。 String left = smoney.substring(0, smoney.indexOf(".")); String right = smoney.substring(smoney.indexOf(".") + 1); String result = convertLeft(left) + convertRight(right); return result; } else { return convertLeft(smoney); } } catch (IllegalArgumentException e) { System.out.println(e.getMessage()); System.out.println("请输入转换范围内现金"); return null; } } private static String convertLeft(String left) { //处理整数部分。 int length = left.length(); //根据单位'亿','万','元',把整数部分分为3种情况处理。 if (length <= 4) { //金额在千元以内。 if (length == 1 && Integer.valueOf(left) == 0) //金额为'0'元时的特殊情况。 return "零元"; return convertPart(left, length); } else if (length <= 8) { //金额在千万元以内。 String part1 = left.substring(0, length - 4); String part2 = left.substring(length - 4, length); String result1 = convertPart(part1, length); String result2 = convertPart(part2, 4); return result1 + result2; } else if (length <= 12) { //金额在千亿元以内。 String part1 = left.substring(0, length - 8); //截取单位为'亿'部分数值。 String part2 = left.substring(length - 8, length - 4); //截取单位为'万'部分数值。 String part3 = left.substring(length - 4, length); //截取单位为'元'部分数值。 String result1 = convertPart(part1, length); //转换单位为'亿'部分数值。 String result2 = convertPart(part2, 8); //转换单位为'万'部分数值。 String result3 = convertPart(part3, 4); //转换单位为'元'部分数值。 String result = result1 + result2 + result3; return result; } else { throw new IllegalArgumentException("超出转换数值范围!"); } } private static String convertRight(String right) { //处理小数部分。 String result = ""; String number = ""; String unit = ""; int length = right.length(); for (int i = 0; i < length; i++) { String detail = right.substring(i, i + 1); int value = Integer.valueOf(detail); number = upperNumber[value]; unit = cashUnitRight[i]; result = result.concat(number).concat(unit); } result = result.replaceAll("零角", "").replaceAll("零分", "").replaceAll("零厘", ""); return result; } private static String convertPart(String part, int position) { String result = ""; String number = ""; String unit = ""; if (part.equals("0000") && position == 8) //用于排除单位为'万'时,四位数值均为'0'的情况。 return ""; for (int i = 0; i < part.length(); i++) { int value = Integer.valueOf(String.valueOf(part.charAt(i))); number = upperNumber[value]; unit = cashUnitLeft[position - 1 - i]; result = result.concat(number).concat(unit); } result = result.replaceAll("零仟", "零").replaceAll("零佰", "零") //把单位'亿','万','元'放到最后替换。 .replaceAll("零拾", "零").replaceAll("零零", "零").replaceAll("零零", "零").replaceAll("零亿", "亿").replaceAll("零万", "万").replaceAll("零元", "元"); // result = result.replaceAll("零仟", "零"); // result = result.replaceAll("零佰", "零"); // result = result.replaceAll("零拾", "零"); // result = result.replaceAll("零零", "零"); // result = result.replaceAll("零零", "零"); // result = result.replaceAll("零亿", "亿"); // result = result.replaceAll("零万", "万"); // result = result.replaceAll("零元", "元"); System.out.println(result); return result; } }