| | |
| | | package com.ruoyi.web.controller.project; |
| | | |
| | | import java.io.*; |
| | | import java.text.DecimalFormat; |
| | | import java.text.SimpleDateFormat; |
| | | import java.util.*; |
| | | |
| | | import com.alibaba.fastjson.JSONArray; |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.ruoyi.common.annotation.Log; |
| | | 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.HttpClientKit; |
| | | import com.ruoyi.common.utils.SecurityUtils; |
| | | 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.domain.SysPost; |
| | | 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 org.apache.commons.lang.ArrayUtils; |
| | | import org.apache.commons.lang.StringUtils; |
| | | import org.apache.ibatis.annotations.Options; |
| | | import org.springframework.security.access.prepost.PreAuthorize; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.web.bind.annotation.GetMapping; |
| | | import org.springframework.web.bind.annotation.PostMapping; |
| | | import org.springframework.web.bind.annotation.PutMapping; |
| | | import org.springframework.web.bind.annotation.DeleteMapping; |
| | | import org.springframework.web.bind.annotation.PathVariable; |
| | | import org.springframework.web.bind.annotation.RequestBody; |
| | | import org.springframework.web.bind.annotation.RequestMapping; |
| | | import org.springframework.web.bind.annotation.RestController; |
| | | import com.ruoyi.common.annotation.Log; |
| | | import com.ruoyi.common.annotation.RepeatSubmit; |
| | | import com.ruoyi.common.core.controller.BaseController; |
| | | import com.ruoyi.common.core.domain.AjaxResult; |
| | | import com.ruoyi.common.enums.BusinessType; |
| | | import com.ruoyi.common.utils.poi.ExcelUtil; |
| | | import com.ruoyi.common.core.page.TableDataInfo; |
| | | import freemarker.template.Configuration; |
| | | import org.springframework.util.CollectionUtils; |
| | | import org.springframework.web.bind.annotation.*; |
| | | |
| | | import java.io.*; |
| | | import java.math.BigDecimal; |
| | | import java.text.DecimalFormat; |
| | | import java.text.SimpleDateFormat; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | | |
| | | |
| | | /** |
| | | * 报销申请Controller |
| | | * |
| | | * |
| | | * @author ruoyi |
| | | * @date 2022-01-24 |
| | | */ |
| | | @Api("报销申请") |
| | | @RestController |
| | | @RequestMapping("/project/reimbursement") |
| | | public class ServiceReimbursementController extends BaseController |
| | | { |
| | | public class ServiceReimbursementController extends BaseController { |
| | | @Autowired |
| | | private IServiceReimbursementService serviceReimbursementService; |
| | | |
| | | @Autowired |
| | | private IServiceReimbursementpayeeService reimbursementpayeeService; |
| | | |
| | | @Autowired |
| | | private IServiceReimbursementSharedService serviceReimbursementServiceShare; |
| | | |
| | | @Autowired |
| | | private IServiceReimbursementdetailService serviceReimbursementdetailService; |
| | |
| | | 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[] = { "零", "壹", "贰", "叁", "肆", "伍", "陆", "柒","捌", "玖" }; |
| | | |
| | | static String cashUnitLeft[] = {"元", "拾", "佰", "仟", "万", "拾", "佰", "仟", "亿", "拾", "佰", "仟", "万"}; |
| | | static String cashUnitRight[] = {"角", "分", "厘"}; |
| | | static String upperNumber[] = {"零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"}; |
| | | |
| | | /** |
| | | * 查询报销申请列表 |
| | |
| | | //@PreAuthorize("@ss.hasPermi('project:reimbursement:list')") |
| | | @Log(title = "查询报销申请列表", businessType = BusinessType.OTHER) |
| | | @GetMapping("/list") |
| | | public TableDataInfo list(ServiceReimbursement serviceReimbursement) |
| | | { |
| | | public TableDataInfo list(ServiceReimbursement serviceReimbursement) { |
| | | SysUser user = SecurityUtils.getLoginUser().getUser(); |
| | | serviceReimbursement.setCreateBy(user.getUserName()); |
| | | startPage(); |
| | |
| | | */ |
| | | @ApiOperation("根据日期查询报销申请列表") |
| | | @GetMapping("/listWithDate") |
| | | public TableDataInfo listWithDate(ServiceReimbursementDto serviceReimbursementdto) |
| | | { |
| | | public TableDataInfo listWithDate(ServiceReimbursementDto serviceReimbursementdto) { |
| | | startPage(); |
| | | List<ServiceReimbursement> list = serviceReimbursementService.selectSearchList(serviceReimbursementdto); |
| | | return getDataTable(list); |
| | |
| | | @ApiOperation("根据权限显示审核列表") |
| | | @Log(title = "根据权限显示审核列表", businessType = BusinessType.OTHER) |
| | | @GetMapping("/listbypower") |
| | | public TableDataInfo getListBypower(SpFinancialExpensesIn spFinancialExpensesIn) |
| | | { |
| | | 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 pageNum=spFinancialExpensesIn.getPageNum(); |
| | | Integer pageSize=spFinancialExpensesIn.getPageSize(); |
| | | String APPLICANT = spFinancialExpensesIn.getAPPLICANT(); |
| | | String APPLICATIONBEGTIME = spFinancialExpensesIn.getAPPLICATIONBEGTIME(); |
| | | String APPLICATIONENDTIME = spFinancialExpensesIn.getAPPLICATIONENDTIME(); |
| | | Integer CHECKFLAG = spFinancialExpensesIn.getCHECKFLAG(); |
| | | Integer APPLYTYPE = spFinancialExpensesIn.getAPPLYTYPE(); |
| | | Integer pageNum = spFinancialExpensesIn.getPageNum(); |
| | | Integer pageSize = spFinancialExpensesIn.getPageSize(); |
| | | |
| | | if(pageNum==null) |
| | | { |
| | | pageNum=1; |
| | | if (pageNum == null) { |
| | | pageNum = 1; |
| | | } |
| | | |
| | | if(pageSize==null) |
| | | { |
| | | pageSize=10; |
| | | if (pageSize == null) { |
| | | pageSize = 10; |
| | | } |
| | | |
| | | if(APPLICANT==null) |
| | | { |
| | | APPLICANT=""; |
| | | if (APPLICANT == null) { |
| | | APPLICANT = ""; |
| | | } |
| | | |
| | | if(APPLICATIONBEGTIME==null) |
| | | { |
| | | APPLICATIONBEGTIME=""; |
| | | if (APPLICATIONBEGTIME == null) { |
| | | APPLICATIONBEGTIME = ""; |
| | | } |
| | | |
| | | if(APPLICATIONENDTIME==null) |
| | | { |
| | | APPLICATIONENDTIME=""; |
| | | if (APPLICATIONENDTIME == null) { |
| | | APPLICATIONENDTIME = ""; |
| | | } |
| | | //startPage(); |
| | | List<SpFinancialExpensesReimbursementOut> list = serviceReimbursementService.getListBypower(loginUser.getUsername(),1,APPLICANT,APPLICATIONBEGTIME,APPLICATIONENDTIME,loginUser.getDeptId().toString(),CHECKFLAG,APPLYTYPE); |
| | | return getCustomDataTable(list,pageNum,pageSize); |
| | | List<SpFinancialExpensesReimbursementOut> list = serviceReimbursementService.getListBypower(loginUser.getUsername(), 1, APPLICANT, APPLICATIONBEGTIME, APPLICATIONENDTIME, loginUser.getDeptId().toString(), CHECKFLAG, APPLYTYPE); |
| | | return getCustomDataTable(list, pageNum, pageSize); |
| | | } |
| | | |
| | | /** |
| | |
| | | //@PreAuthorize("@ss.hasPermi('project:reimbursement:export')") |
| | | @Log(title = "报销申请", businessType = BusinessType.EXPORT) |
| | | @GetMapping("/export") |
| | | public AjaxResult export(ServiceReimbursement serviceReimbursement) |
| | | { |
| | | public AjaxResult export(ServiceReimbursement serviceReimbursement) { |
| | | List<ServiceReimbursement> list = serviceReimbursementService.queryList(serviceReimbursement); |
| | | ExcelUtil<ServiceReimbursement> util = new ExcelUtil<ServiceReimbursement>(ServiceReimbursement.class); |
| | | return util.exportExcel(list, "报销申请数据"); |
| | |
| | | @ApiOperation("获取报销申请详细信息") |
| | | //@PreAuthorize("@ss.hasPermi('project:reimbursement:query')") |
| | | @GetMapping(value = "/{id}") |
| | | public AjaxResult getInfo(@PathVariable("id") Long id) |
| | | { |
| | | public AjaxResult getInfo(@PathVariable("id") Long id) { |
| | | return AjaxResult.success(serviceReimbursementService.getById(id)); |
| | | } |
| | | |
| | | @GetMapping("/getMaxId") |
| | | public AjaxResult getMaxId(){ |
| | | public AjaxResult getMaxId() { |
| | | return AjaxResult.success(serviceReimbursementService.getMaxId()); |
| | | } |
| | | |
| | | @GetMapping("/getRBDetailList/{id}") |
| | | public AjaxResult getRBDetailList(@PathVariable("id") Long id){ |
| | | public AjaxResult getRBDetailList(@PathVariable("id") Long id) { |
| | | return AjaxResult.success(serviceReimbursementService.getRBDetailList(id)); |
| | | } |
| | | |
| | | /** |
| | | * 往service_reimbursement_share,往service_reimbursementdetail_share,往service_reimbursementpyee_share新增备份数据 |
| | | * |
| | | * @param id |
| | | * @return |
| | | */ |
| | | @GetMapping("/addShareData/{id}") |
| | | public AjaxResult addSharedData(@PathVariable("id") Long id) { |
| | | |
| | | return AjaxResult.success(serviceReimbursementService.addSharedData(id)); |
| | | } |
| | | |
| | | /** |
| | |
| | | @PostMapping |
| | | @RepeatSubmit |
| | | @Options(useGeneratedKeys = true, keyProperty = "id") |
| | | public AjaxResult add(@RequestBody ServiceReimbursement serviceReimbursement) |
| | | { |
| | | public AjaxResult add(@RequestBody ServiceReimbursement serviceReimbursement) { |
| | | |
| | | boolean b = serviceReimbursementService.save(serviceReimbursement); |
| | | // if (b) { |
| | | // addReiSharedDatd(serviceReimbursement, 1); |
| | | // } |
| | | Long id = serviceReimbursement.getId(); |
| | | return AjaxResult.success(id); |
| | | } |
| | | |
| | | public int addReiSharedDatd(ServiceReimbursement serviceReimbursement, int nType) { |
| | | //remShare = ; |
| | | ServiceReimbursementShared remShare = new ServiceReimbursementShared(); |
| | | if (nType == 1) { |
| | | // remShare = new ServiceReimbursementShared(); |
| | | remShare.setReimid(serviceReimbursement.getId()); |
| | | } else //modify |
| | | { |
| | | List<ServiceReimbursementShared> remlist = serviceReimbursementServiceShare.getRemShareInfoByRemId(serviceReimbursement.getId()); |
| | | if (!CollectionUtils.isEmpty(remlist)) remShare = remlist.get(0); |
| | | } |
| | | |
| | | remShare.setUserno(serviceReimbursement.getUserno()); |
| | | remShare.setUsername(serviceReimbursement.getUsername()); |
| | | remShare.setTravelers(serviceReimbursement.getTravelers()); |
| | | remShare.setIdcardtype(serviceReimbursement.getIdcardtype()); |
| | | remShare.setIdcardno(serviceReimbursement.getIdcardno()); |
| | | remShare.setPhone(serviceReimbursement.getPhone()); |
| | | remShare.setDepositbank(serviceReimbursement.getDepositbank()); |
| | | remShare.setBankcardno(serviceReimbursement.getBankcardno()); |
| | | remShare.setBranchbankname(serviceReimbursement.getBranchbankname()); |
| | | remShare.setAnnexbankcard(serviceReimbursement.getAnnexbankcard()); |
| | | remShare.setAnnexfiles(serviceReimbursement.getAnnexfiles()); |
| | | //remShare.setAnnexfiles(serviceReimbursement.getAnnexfiles()); |
| | | // remShare.setAmountrequested(BigDecimal.valueOf(serviceReimbursement.getAmountrequested())); |
| | | |
| | | Double nTemp = serviceReimbursement.getAmountrequested(); |
| | | if (nTemp == null) nTemp = 0d; |
| | | remShare.setAmountrequested(BigDecimal.valueOf(nTemp)); |
| | | |
| | | nTemp = serviceReimbursement.getPrepaidamount(); |
| | | if (nTemp == null) nTemp = 0.0; |
| | | remShare.setPrepaidamount(BigDecimal.valueOf(nTemp)); |
| | | |
| | | remShare.setInvoicecount(serviceReimbursement.getInvoicecount()); |
| | | remShare.setAttachcount(serviceReimbursement.getAttachcount()); |
| | | remShare.setManagerno(serviceReimbursement.getManagerno()); |
| | | remShare.setManagername(serviceReimbursement.getManagername()); |
| | | remShare.setDeptmentno(serviceReimbursement.getDeptmentno()); |
| | | remShare.setDeptmentname(serviceReimbursement.getDeptmentname()); |
| | | remShare.setOpochecker(serviceReimbursement.getOpochecker()); |
| | | remShare.setFinvicepresident(serviceReimbursement.getFinvicepresident()); |
| | | remShare.setBusvicepresident(serviceReimbursement.getBusvicepresident()); |
| | | remShare.setOfficedirector(serviceReimbursement.getOfficedirector()); |
| | | remShare.setFinancedirector(serviceReimbursement.getFinancedirector()); |
| | | remShare.setFinancechecher(serviceReimbursement.getFinancechecher()); |
| | | remShare.setInfoid(serviceReimbursement.getInfoid()); |
| | | remShare.setDonorno(serviceReimbursement.getDonorno()); |
| | | |
| | | remShare.setDonorname(serviceReimbursement.getDonorname()); |
| | | remShare.setReason(serviceReimbursement.getReason()); |
| | | remShare.setRecordstatus(serviceReimbursement.getRecordstatus()); |
| | | remShare.setUploadflag(serviceReimbursement.getUploadflag()); |
| | | remShare.setUploadtime(serviceReimbursement.getUploadtime()); |
| | | |
| | | nTemp = serviceReimbursement.getTotalamount(); |
| | | if (nTemp == null) nTemp = 0.0; |
| | | remShare.setTotalamount(BigDecimal.valueOf(nTemp)); |
| | | |
| | | remShare.setBigstrmoney(serviceReimbursement.getBigstrmoney()); |
| | | remShare.setFlowlevel(serviceReimbursement.getFlowlevel()); |
| | | remShare.setCosttype(serviceReimbursement.getCosttype()); |
| | | remShare.setCosttypename(serviceReimbursement.getCosttypename()); |
| | | remShare.setFileurl(serviceReimbursement.getAnnexfiles()); |
| | | remShare.setDonorbank(serviceReimbursement.getDonorbank()); |
| | | remShare.setDonorbankcard(serviceReimbursement.getDonorbankcard()); |
| | | remShare.setDonorremark(serviceReimbursement.getDonorremark()); |
| | | |
| | | nTemp = serviceReimbursement.getDonoramount(); |
| | | if (nTemp == null) nTemp = 0.0; |
| | | remShare.setDonoramount(nTemp); |
| | | remShare.setDonorrelatives(serviceReimbursement.getDonorrelatives()); |
| | | //remShare.setOaid(serviceReimbursement.getOaid()); |
| | | //remShare.setDonorno(serviceReimbursement.getDonorno()); |
| | | |
| | | boolean bRet = false; |
| | | if (nType == 1) { |
| | | bRet = serviceReimbursementServiceShare.save(remShare); |
| | | } else { |
| | | //remShare.setId(serviceReimbursement.); |
| | | bRet = serviceReimbursementServiceShare.updateById(remShare); |
| | | } |
| | | |
| | | //if(!bRet) return -1; |
| | | String strMutfileUrl = remShare.getFileurl(); |
| | | //有附件时才调用第三方进行上传 |
| | | if (strMutfileUrl == null) return 0; |
| | | if (strMutfileUrl.isEmpty()) return 0; |
| | | |
| | | try { |
| | | uploadOAFileAndUpdateDb(remShare); |
| | | } catch (Exception e) { |
| | | logger.error("调用第三方接口出错!"); |
| | | e.printStackTrace(); |
| | | } |
| | | |
| | | //此处保存成功后要上传OA,保存返回值 |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | |
| | | int uploadOAFileAndUpdateDb(ServiceReimbursementShared 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);//得到返回的token? |
| | | |
| | | JSONObject json1 = JSONObject.parseObject(strRes); |
| | | strRes = json1.get("id").toString(); |
| | | |
| | | ///if(strRes.isEmpty() || "" == strRes) return -1;// 为空代表失败 |
| | | |
| | | //下面需求调用文件的接口,调用成功返回后,得到filename和fileid 用这二个值去更新数据 |
| | | |
| | | String filePath = RuoYiConfig.getUploadPath(); |
| | | String strMutfileUrl = remShare.getFileurl();//可能存在多个地址,以,分开 |
| | | |
| | | 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(); |
| | | } |
| | | |
| | | |
| | | /*CloseableHttpClient httpClient = HttpClients.createDefault(); |
| | | //创建post方法连接实例,在post方法中传入待连接地址 |
| | | HttpPost httpPost = new HttpPost(strFUrl); |
| | | CloseableHttpResponse response = null; |
| | | |
| | | String struploadResult = ""; |
| | | try { |
| | | //设置请求参数(类似html页面中name属性) |
| | | MultipartEntityBuilder entity = MultipartEntityBuilder.create(); |
| | | //entity.setMode(HttpMultipartMode.BROWSER_COMPATIBLE); |
| | | entity.setCharset(Charset.forName("UTF-8")); |
| | | |
| | | byte[] fileBytes = Files.readAllBytes(Paths.get(strFile)); |
| | | if (fileBytes != null) { |
| | | //内容类型,用于定义网络文件的类型和网页的编码,决定文件接收方将以什么形式、什么编码读取这个文件 |
| | | ContentType OCTEC_STREAM = ContentType.create("application/octet-stream", Charset.forName("UTF-8")); |
| | | //添加文件 |
| | | entity.addBinaryBody("file", fileBytes, OCTEC_STREAM, strTemp); |
| | | } |
| | | |
| | | httpPost.setEntity(entity.build()); |
| | | //发起请求,并返回请求响应 |
| | | response = httpClient.execute(httpPost); |
| | | struploadResult = EntityUtils.toString(response.getEntity(), "utf-8"); |
| | | } |
| | | 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 = serviceReimbursementServiceShare.updateById(remShare); |
| | | if (!bRet) return -1; |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | /** |
| | |
| | | @ApiOperation("差旅费上报") |
| | | @Log(title = "差旅费上报", businessType = BusinessType.OTHER) |
| | | @PostMapping("/travelexpensereport") |
| | | public AjaxResult travelexpensereport(@RequestBody CheckFundVO checkFundVO) |
| | | { |
| | | ServiceReimbursement serviceReimbursement= serviceReimbursementService.getById(checkFundVO.getFundid()); |
| | | if(serviceReimbursement!=null) |
| | | { |
| | | Integer TotalLevel=0; |
| | | public AjaxResult travelexpensereport(@RequestBody CheckFundVO checkFundVO) { |
| | | ServiceReimbursement serviceReimbursement = serviceReimbursementService.getById(checkFundVO.getFundid()); |
| | | if (serviceReimbursement != null) { |
| | | Integer TotalLevel = 0; |
| | | LoginUser loginUser = getLoginUser(); |
| | | SysUser user = loginUser.getUser(); |
| | | List<Integer> postids =postService.selectPostListByUserId(loginUser.getUserId()); |
| | | List<Integer> postids = postService.selectPostListByUserId(loginUser.getUserId()); |
| | | |
| | | if(!postids.contains(2)) |
| | | { |
| | | serviceReimbursement.setFlowlevel(1); |
| | | if (!postids.contains(2)) { |
| | | serviceReimbursement.setFlowlevel(1L); |
| | | serviceReimbursement.setRecordstatus(2); |
| | | } |
| | | else |
| | | { |
| | | serviceReimbursement.setFlowlevel(0); |
| | | } else { |
| | | serviceReimbursement.setFlowlevel(0L); |
| | | serviceReimbursement.setRecordstatus(0); |
| | | } |
| | | |
| | | if(!postids.contains(2)) { |
| | | if (!postids.contains(2)) { |
| | | ServiceFundflow serviceFundflow = new ServiceFundflow(); |
| | | serviceFundflow.setFundid(serviceReimbursement.getId()); |
| | | serviceFundflow.setCheckuserno(user.getUserName()); |
| | |
| | | serviceReimbursementService.updateById(serviceReimbursement); |
| | | |
| | | return AjaxResult.success(); |
| | | } |
| | | else |
| | | { |
| | | return AjaxResult.error(HttpStatus.NO_CONTENT,"费用编号不正确"); |
| | | } else { |
| | | return AjaxResult.error(HttpStatus.NO_CONTENT, "费用编号不正确"); |
| | | } |
| | | } |
| | | |
| | |
| | | @ApiOperation("审核费用") |
| | | @Log(title = "审核费用", businessType = BusinessType.OTHER) |
| | | @PostMapping("/checkfund") |
| | | public AjaxResult checkFund(@RequestBody CheckFundVO checkFundVO) |
| | | { |
| | | ServiceReimbursement serviceReimbursement= serviceReimbursementService.getById(checkFundVO.getFundid()); |
| | | if(serviceReimbursement!=null) |
| | | { |
| | | Integer TotalLevel=0; |
| | | public AjaxResult checkFund(@RequestBody CheckFundVO checkFundVO) { |
| | | ServiceReimbursement serviceReimbursement = serviceReimbursementService.getById(checkFundVO.getFundid()); |
| | | if (serviceReimbursement != null) { |
| | | Integer totalLevel = 0; |
| | | LoginUser loginUser = getLoginUser(); |
| | | ServiceFundflowrule serviceFundflowrule=new ServiceFundflowrule(); |
| | | ServiceFundflowrule serviceFundflowrule = new ServiceFundflowrule(); |
| | | serviceFundflowrule.setFundtype(1); |
| | | serviceFundflowrule.setApplytype("0"); |
| | | serviceFundflowrule.setCheckuserno(loginUser.getUsername()); |
| | | List<ServiceFundflowrule> serviceFundflowrules= serviceFundflowruleService.queryList(serviceFundflowrule); |
| | | List<ServiceFundflowrule> serviceFundflowrules = serviceFundflowruleService.queryList(serviceFundflowrule); |
| | | |
| | | if(serviceFundflowrules==null || serviceFundflowrules.stream().count()==0) |
| | | { |
| | | return AjaxResult.error(HttpStatus.ERROR,"当前人员无此记录审核权限"); |
| | | 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.get(0).getFlowlevel() - 1 != serviceReimbursement.getFlowlevel()) { |
| | | return AjaxResult.error(HttpStatus.ERROR, "当前人员与此记录的审核级别不符"); |
| | | } |
| | | |
| | | if(serviceFundflowrules!=null && serviceFundflowrules.stream().count()>0) |
| | | { |
| | | TotalLevel=serviceFundflowrules.get(0).getTotallevel(); |
| | | if (serviceFundflowrules != null && serviceFundflowrules.stream().count() > 0) { |
| | | totalLevel = serviceFundflowrules.get(0).getTotallevel(); |
| | | |
| | | |
| | | } |
| | | Integer CheckFlag=0; |
| | | Integer RecordStatus=serviceReimbursement.getRecordstatus(); |
| | | Integer FlowLevel=serviceReimbursement.getFlowlevel(); |
| | | Integer OriginalFlowLevel=FlowLevel; |
| | | if(checkFundVO.getFlowconclusion()==1) |
| | | { |
| | | CheckFlag=1; |
| | | if(TotalLevel==0) |
| | | { |
| | | RecordStatus=99; |
| | | } |
| | | else |
| | | { |
| | | if(TotalLevel==FlowLevel+1) |
| | | { |
| | | RecordStatus=99; |
| | | } |
| | | else |
| | | { |
| | | RecordStatus = (FlowLevel+1)*2; |
| | | Integer CheckFlag = 0; |
| | | Integer RecordStatus = serviceReimbursement.getRecordstatus(); |
| | | Integer FlowLevel = Integer.valueOf(serviceReimbursement.getFlowlevel().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; |
| | | } |
| | | } |
| | | FlowLevel=FlowLevel+1; |
| | | } |
| | | else |
| | | { |
| | | CheckFlag=2; |
| | | RecordStatus = (FlowLevel+1)*2 - 1; |
| | | FlowLevel=(FlowLevel-1); |
| | | if(FlowLevel<0) |
| | | { |
| | | FlowLevel=0; |
| | | FlowLevel = FlowLevel + 1; |
| | | } else { |
| | | CheckFlag = 2; |
| | | RecordStatus = (FlowLevel + 1) * 2 - 1; |
| | | FlowLevel = (FlowLevel - 1); |
| | | if (FlowLevel < 0) { |
| | | FlowLevel = 0; |
| | | } |
| | | } |
| | | |
| | | serviceReimbursement.setRecordstatus(RecordStatus); |
| | | serviceReimbursement.setFlowlevel(FlowLevel); |
| | | serviceReimbursement.setFlowlevel(Long.valueOf(FlowLevel.toString())); |
| | | |
| | | ServiceFundflow serviceFundflow=new ServiceFundflow(); |
| | | ServiceFundflow serviceFundflow = new ServiceFundflow(); |
| | | SysUser user = loginUser.getUser(); |
| | | serviceFundflow.setFundid(serviceReimbursement.getId()); |
| | | serviceFundflow.setCheckuserno(user.getUserName()); |
| | |
| | | serviceFundflow.setApplytype("0"); |
| | | serviceFundflow.setFlowconclusion(CheckFlag); |
| | | serviceFundflow.setFlowcontent(checkFundVO.getFlowcontent()); |
| | | serviceFundflow.setFlowlevel(OriginalFlowLevel+1); |
| | | serviceFundflow.setFlowlevel(OriginalFlowLevel + 1); |
| | | serviceFundflowService.save(serviceFundflow); |
| | | |
| | | List<Integer> postids =postService.selectPostListByUserId(loginUser.getUserId()); |
| | | List<Integer> postids = postService.selectPostListByUserId(loginUser.getUserId()); |
| | | |
| | | if(!postids.contains(2)) |
| | | { |
| | | if(CheckFlag==2 && OriginalFlowLevel==1) |
| | | { |
| | | ServiceFundflow serviceFundflowAuto=new ServiceFundflow(); |
| | | if (!postids.contains(2)) { |
| | | if (CheckFlag == 2 && OriginalFlowLevel == 1) { |
| | | ServiceFundflow serviceFundflowAuto = new ServiceFundflow(); |
| | | serviceFundflowAuto.setFundid(serviceReimbursement.getId()); |
| | | serviceFundflowAuto.setCheckuserno(user.getUserName()); |
| | | serviceFundflowAuto.setCheckusername(user.getNickName()); |
| | |
| | | |
| | | serviceReimbursementService.updateById(serviceReimbursement); |
| | | |
| | | ServiceSystemmessage serviceSystemmessage=new ServiceSystemmessage(); |
| | | ServiceSystemmessage serviceSystemmessage = new ServiceSystemmessage(); |
| | | serviceSystemmessage.setFundtype(1); |
| | | serviceSystemmessage.setApplytype("0"); |
| | | serviceSystemmessage.setSenduserno(user.getUserName()); |
| | |
| | | serviceSystemmessage.setIsread(0); |
| | | serviceSystemmessage.setMessagetype(1); |
| | | serviceSystemmessage.setRelevantno(serviceReimbursement.getId()); |
| | | if(CheckFlag==1) |
| | | { |
| | | if (CheckFlag == 1) { |
| | | //通过 |
| | | serviceSystemmessage.setMessagetitle(""+(OriginalFlowLevel+1)+"级审核通过"); |
| | | serviceSystemmessage.setMessagecontent("您"+new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceReimbursement.getCreateTime())+"提交的关于捐献案例【"+serviceReimbursement.getDonorname()+"】的差旅费申请已通过"+(OriginalFlowLevel+1)+"级审核"); |
| | | |
| | | } |
| | | else |
| | | { |
| | | serviceSystemmessage.setMessagetitle("" + (OriginalFlowLevel + 1) + "级审核通过"); |
| | | serviceSystemmessage.setMessagecontent("您" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(serviceReimbursement.getCreateTime()) + "提交的关于捐献案例【" + serviceReimbursement.getDonorname() + "】的差旅费申请已通过" + (OriginalFlowLevel + 1) + "级审核"); |
| | | 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.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,"费用编号不正确"); |
| | | } else { |
| | | return AjaxResult.error(HttpStatus.NO_CONTENT, "费用编号不正确"); |
| | | } |
| | | } |
| | | |
| | |
| | | //@PreAuthorize("@ss.hasPermi('project:reimbursement:edit')") |
| | | @Log(title = "报销申请", businessType = BusinessType.UPDATE) |
| | | @PutMapping |
| | | @RepeatSubmit |
| | | public AjaxResult edit(@RequestBody ServiceReimbursement serviceReimbursement) |
| | | { |
| | | return toAjax(serviceReimbursementService.updateById(serviceReimbursement)); |
| | | @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<ReimbursementService> serviceReimbursement) { |
| | | boolean b = serviceReimbursementService.updateById(null); |
| | | // if (b) { |
| | | // addReiSharedDatd(null, 2); |
| | | // } |
| | | return toAjax(b); |
| | | } |
| | | |
| | | /** |
| | |
| | | //@PreAuthorize("@ss.hasPermi('project:reimbursement:remove')") |
| | | @Log(title = "报销申请", businessType = BusinessType.DELETE) |
| | | @DeleteMapping("/{ids}") |
| | | public AjaxResult remove(@PathVariable Long[] ids) |
| | | { |
| | | public AjaxResult remove(@PathVariable Long[] ids) { |
| | | return toAjax(serviceReimbursementService.removeByIds(Arrays.asList(ids))); |
| | | } |
| | | |
| | |
| | | @GetMapping(value = "/download/{id}") |
| | | public Map downloadInfo(@PathVariable("id") Long id) throws IOException { |
| | | Map dataMap = new HashMap(); |
| | | getData(dataMap,id); |
| | | getData(dataMap, id); |
| | | String filePath = getClass().getResource("/template/").getPath(); |
| | | System.out.println(filePath); |
| | | //设置模本装置方法和路径,FreeMarker支持多种模板装载方法。可以重servlet,classpath,数据库教程装载, |
| | | configuration.setDirectoryForTemplateLoading(new File(filePath)); |
| | | |
| | | Template t=null; |
| | | Template t = null; |
| | | try { |
| | | //捐献表.ftl为要装载的模板 |
| | | t = configuration.getTemplate("差旅费报销申请单.ftl"); |
| | |
| | | e.printStackTrace(); |
| | | } |
| | | String newTime = String.valueOf(Calendar.getInstance().getTimeInMillis()); |
| | | String name = "差旅费报销申请单_"+dataMap.get("XM")+"_"+ newTime; |
| | | String name = "差旅费报销申请单_" + dataMap.get("XM") + "_" + newTime; |
| | | |
| | | //输出文档路径及名称 |
| | | File outFile = new File(RuoYiConfig.getProfile()+"/download/wordtemplate/"+name+".doc"); |
| | | 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")); |
| | | out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile), "utf-8")); |
| | | |
| | | } catch (FileNotFoundException e1) { |
| | | e1.printStackTrace(); |
| | |
| | | } catch (TemplateException e) { |
| | | e.printStackTrace(); |
| | | } |
| | | Map<String ,Object> map = new HashMap<>(); |
| | | map.put("downloadUrl", "/profile/download/wordtemplate/"+name+".doc"); |
| | | Map<String, Object> map = new HashMap<>(); |
| | | map.put("downloadUrl", "/profile/download/wordtemplate/" + name + ".doc"); |
| | | return map; |
| | | } |
| | | |
| | | private void getData(Map dataMap,Long id) { |
| | | ServiceReimbursement serviceReimbursement = serviceReimbursementService.getById(id); |
| | | if (serviceReimbursement == null) { |
| | | throw new ServiceException("下载失败,用户信息出错", HttpStatus.NO_CONTENT); |
| | | private void getData(Map dataMap, Long id) { |
| | | |
| | | //ServiceReimbursement serviceReimbursement = serviceReimbursementService.getById(id); |
| | | ServiceReimbursement serviceReimbursement = null; |
| | | ServiceReimbursementEo serviceReimbursementEo = new ServiceReimbursementEo(); |
| | | serviceReimbursementEo.setId(id); |
| | | List<ServiceReimbursementEo> rdInfoByItem = serviceReimbursementService.getRDInfoByItem(serviceReimbursementEo); |
| | | //获取报销支付信息 |
| | | List<ServiceReimbursementpayee> reimbursementpayeeInfo = reimbursementpayeeService.getReimbursementpayeeInfo(serviceReimbursementEo); |
| | | |
| | | Map<String, List<ServiceReimbursementEo>> listMap = rdInfoByItem.stream().collect(Collectors.groupingBy(ServiceReimbursementEo::getPersontype)); |
| | | List<Map<String, BigDecimal>> 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<String, BigDecimal> map = new HashMap<>(); |
| | | List<ServiceReimbursementEo> 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.getFoodexpenses()).add(serviceReimbursementEo1.getFoodallowance()).add(serviceReimbursementEo1.getOtherexpense()).add(serviceReimbursementEo1.getOtherfeeamount()); |
| | | } |
| | | map.put(key, otherMoney); |
| | | list.add(map); |
| | | // 不为专家或家属 |
| | | if (!key.equals("3") && !key.equals("4")) { |
| | | //将上一次的清空 |
| | | FYXM1.delete(0, FYXM1.length()); |
| | | //再新增 |
| | | otherMoneyall = otherMoneyall.add(otherMoney); |
| | | FYXM1.append("OPO工作人员" + ":" + otherMoneyall + " "); |
| | | } else { |
| | | if (flag == 0) { |
| | | key1 = key; |
| | | flag = 1; |
| | | } |
| | | if (key1 == key) { |
| | | FYXM2.append(PersonType.getInfoByCode(key) + ":" + otherMoney); |
| | | allMoney = allMoney.add(otherMoney); |
| | | } else { |
| | | FYXM3.append(PersonType.getInfoByCode(key) + ":" + 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); |
| | | } |
| | | } |
| | | |
| | | |
| | | Date dt = serviceReimbursement.getCreateTime(); |
| | | 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("TBYYMMDD", time); |
| | | dataMap.put("BXDFJ", serviceReimbursement.getAttachcount() == 0 ? " " : "" + serviceReimbursement.getAttachcount()); |
| | | dataMap.put("JXZXM", serviceReimbursement.getDonorname() == null ? "" : serviceReimbursement.getDonorname()); |
| | | dataMap.put("JSR", serviceReimbursement.getUsername() == null ? "" : serviceReimbursement.getUsername()); |
| | | dataMap.put("FYXM1", "差旅费报销总金额: " + String.format("%.2f", serviceReimbursement.getAmountrequested()).toString() + "元"); |
| | | dataMap.put("FYXM2", ""); |
| | | dataMap.put("FYXM3", ""); |
| | | dataMap.put("JEXS", serviceReimbursement.getAmountrequested()); |
| | | //double temp = 0; |
| | | //temp = Math.round(serviceReimbursement.getAmountrequested() * 100) * 0.01d; |
| | | dataMap.put("JEDS", convert(serviceReimbursement.getAmountrequested()) + "整"); |
| | | 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 = ""; |
| | | remark += serviceReimbursement.getCosttypename() == null ? "" : serviceReimbursement.getCosttypename() + "("; |
| | | |
| | | remark += serviceReimbursement.getTravelers() == null ? "" : serviceReimbursement.getTravelers() + ": "; |
| | | |
| | | remark += serviceReimbursement.getIdcardno() == null ? "" : serviceReimbursement.getIdcardno() + "; "; |
| | | |
| | | remark += serviceReimbursement.getDepositbank() == null ? "" : serviceReimbursement.getDepositbank() + ": "; |
| | | |
| | | remark += serviceReimbursement.getBankcardno() == null ? "" : serviceReimbursement.getBankcardno() + ")"; |
| | | remark += "\n"; |
| | | remark += serviceReimbursement.getRemark() == null ? "" : serviceReimbursement.getRemark(); |
| | | for (ServiceReimbursementpayee serviceReimbursementpayee : reimbursementpayeeInfo) { |
| | | remark += "<w:br/> " + 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("YYMMDD", time); |
| | | |
| | | dataMap.put("FJ", serviceReimbursement.getAttachcount() == 0 ? " " : "" + serviceReimbursement.getAttachcount()); |
| | | dataMap.put("FP", serviceReimbursement.getInvoicecount() == 0 ? " " : "" + serviceReimbursement.getInvoicecount()); |
| | | dataMap.put("XM", serviceReimbursement.getTravelers() == null ? "" : serviceReimbursement.getTravelers()); |
| | | dataMap.put("BXR", serviceReimbursement.getUsername() == null ? "" : serviceReimbursement.getUsername()); |
| | | dataMap.put("QYZZ", serviceReimbursement.getManagername() == null ? "" : serviceReimbursement.getManagername()); |
| | | dataMap.put("CCSY", serviceReimbursement.getReason() == null ? "" : serviceReimbursement.getReason()); |
| | | 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<ServiceReimbursementdetail> rd = serviceReimbursementdetailService.getAllDetailsByRBID(id); |
| | | if (rd == null) { |
| | | throw new ServiceException("下载失败,没有对应信息", HttpStatus.NO_CONTENT); |
| | | } |
| | | List<Map<String, Object>> newsList = new ArrayList<Map<String,Object>>(); |
| | | List<Map<String, Object>> newsList = new ArrayList<Map<String, Object>>(); |
| | | int days = 0; |
| | | double te = 0; |
| | | double cf = 0; |
| | | double he = 0; |
| | | double oe = 0; |
| | | double fe = 0; |
| | | double fa = 0; |
| | | double hj = 0; |
| | | double qt = 0; |
| | | for(ServiceReimbursementdetail s : rd) { |
| | | Map<String, Object> map=new HashMap<String, Object>(); |
| | | 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<String, Object> map = new HashMap<String, Object>(); |
| | | |
| | | Date st = s.getStarttime(); |
| | | SimpleDateFormat formatter_st = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); |
| | |
| | | map.put("DA", s.getDeparture() == null ? "" : s.getDeparture()); |
| | | |
| | | Date et = s.getEndtime(); |
| | | SimpleDateFormat formatter_et = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); |
| | | String date_et = formatter_et.format(et); |
| | | String year_et = date_et.substring(0, 4); |
| | | String month_et = date_et.substring(5, 7); |
| | | String day_et = date_et.substring(8, 10); |
| | | 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); |
| | |
| | | days += s.getDays(); |
| | | map.put("JT", s.getTraffictype() == null ? "" : s.getTraffictype()); |
| | | map.put("QTFSM", s.getOtherfeedesc() == null ? "" : s.getOtherfeedesc()); |
| | | map.put("JTF", s.getTrafficexpense() == 0.00 ? "" : String.format("%.2f", s.getTrafficexpense()).toString() + ""); |
| | | te += s.getTrafficexpense(); |
| | | map.put("SNJT", s.getCityfee() == 0.00 ? "" : String.format("%.2f", s.getCityfee()).toString() + ""); |
| | | cf += s.getCityfee(); |
| | | map.put("ZSF", s.getHotelexpense() == 0.00 ? "" : String.format("%.2f", s.getHotelexpense()).toString() + ""); |
| | | he += s.getHotelexpense(); |
| | | map.put("ZF", s.getOtherexpense() == 0.00 ? "" : String.format("%.2f", s.getOtherexpense()).toString() + ""); |
| | | oe += s.getOtherexpense(); |
| | | map.put("HSBX", s.getFoodexpenses() == 0.00 ? "" : String.format("%.2f",s.getFoodexpenses()).toString() + ""); |
| | | fe += s.getFoodexpenses(); |
| | | map.put("HSBZ", s.getFoodallowance() == 0.00 ? "" : String.format("%.2f",s.getFoodallowance()).toString() + ""); |
| | | fa += s.getFoodallowance(); |
| | | map.put("QTF", s.getOtherfeeamount() == 0.00 ? "" : String.format("%.2f",s.getOtherfeeamount()).toString() + ""); |
| | | qt += s.getOtherfeeamount(); |
| | | map.put("HJ", String.format("%.2f", s.getTrafficexpense() + s.getCityfee() + s.getHotelexpense() + s.getOtherexpense() + s.getFoodexpenses() + s.getFoodallowance() + s.getOtherfeeamount()).toString() + ""); |
| | | hj += s.getTrafficexpense() + s.getCityfee() + s.getHotelexpense() + s.getOtherexpense() + s.getFoodexpenses() + s.getFoodallowance() + s.getOtherfeeamount(); |
| | | 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"); |
| | | // DecimalFormat df = new DecimalFormat("0.00"); |
| | | |
| | | hj = new Double(df.format(hj).toString()); |
| | | // hj = new Double(df.format(hj).toString()); |
| | | newsList.add(map); |
| | | } |
| | | |
| | | dataMap.put("list",newsList); |
| | | 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("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("TQTF", "" + String.format("%.2f", qt).toString() + ""); |
| | | dataMap.put("THJ", "" + String.format("%.2f", hj).toString() + ""); |
| | | |
| | | dataMap.put("DS", convert(hj) + "整"); |
| | | dataMap.put("DS", convert(hj.doubleValue()) + "整"); |
| | | //dataMap.put("DS", "整"); |
| | | dataMap.put("XS", String.format("%.2f", hj).toString() + ""); |
| | | |
| | | dataMap.put("R", serviceReimbursement.getCosttypename() == null ? "" : serviceReimbursement.getCosttypename()); |
| | | dataMap.put("R", StringUtils.isEmpty(rdInfoByItem.get(0).getCosttypename()) ? "" : rdInfoByItem.get(0).getCosttypename()); |
| | | |
| | | } |
| | | |
| | | public static String convert(Double money) { |
| | | String smoney = money.toString(); |
| | | try{ |
| | | try { |
| | | if (smoney.indexOf(".") != -1) { //把数值分为整数型和带小数的数值分开处理。 |
| | | String left = smoney.substring(0, smoney.indexOf(".")); |
| | | String right = smoney.substring(smoney.indexOf(".") + 1); |
| | |
| | | } else { |
| | | return convertLeft(smoney); |
| | | } |
| | | }catch(IllegalArgumentException e){ |
| | | } catch (IllegalArgumentException e) { |
| | | System.out.println(e.getMessage()); |
| | | System.out.println("请输入转换范围内现金"); |
| | | return null; |
| | |
| | | int length = left.length(); //根据单位'亿','万','元',把整数部分分为3种情况处理。 |
| | | |
| | | if (length <= 4) { //金额在千元以内。 |
| | | if(length == 1 && Integer.valueOf(left) == 0) //金额为'0'元时的特殊情况。 |
| | | 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 part1 = left.substring(0, length - 4); |
| | | String part2 = left.substring(length - 4, length); |
| | | |
| | | String result1 = convertPart(part1, length); |
| | |
| | | String number = ""; |
| | | String unit = ""; |
| | | |
| | | if(part.equals("0000") && position == 8) //用于排除单位为'万'时,四位数值均为'0'的情况。 |
| | | 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))); |
| | |
| | | } |
| | | |
| | | result = result.replaceAll("零仟", "零").replaceAll("零佰", "零") //把单位'亿','万','元'放到最后替换。 |
| | | .replaceAll("零拾", "零").replaceAll("零零", "零") |
| | | .replaceAll("零零", "零").replaceAll("零亿", "亿") |
| | | .replaceAll("零万", "万").replaceAll("零元", "元"); |
| | | .replaceAll("零拾", "零").replaceAll("零零", "零").replaceAll("零零", "零").replaceAll("零亿", "亿").replaceAll("零万", "万").replaceAll("零元", "元"); |
| | | // result = result.replaceAll("零仟", "零"); |
| | | // result = result.replaceAll("零佰", "零"); |
| | | // result = result.replaceAll("零拾", "零"); |
| | |
| | | System.out.println(result); |
| | | return result; |
| | | } |
| | | |
| | | |
| | | |
| | | } |