package com.ruoyi.web.controller.project;
|
|
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.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.StringUtils;
|
import org.apache.ibatis.annotations.Options;
|
import org.springframework.beans.factory.annotation.Autowired;
|
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 {
|
@Autowired
|
private IServiceReimbursementService serviceReimbursementService;
|
|
@Autowired
|
private IServiceReimbursementpayeeService reimbursementpayeeService;
|
|
@Autowired
|
private IServiceReimbursementSharedService serviceReimbursementServiceShare;
|
|
@Autowired
|
private IServiceReimbursementdetailService serviceReimbursementdetailService;
|
|
@Autowired
|
private IServiceFundflowruleService serviceFundflowruleService;
|
|
@Autowired
|
private IServiceFundflowService serviceFundflowService;
|
|
@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());
|
startPage();
|
List<ServiceReimbursement> list = serviceReimbursementService.queryList(serviceReimbursement);
|
return getDataTable(list);
|
}
|
|
/**
|
* 根据日期查询报销申请列表
|
*/
|
@ApiOperation("根据日期查询报销申请列表")
|
@GetMapping("/listWithDate")
|
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) {
|
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();
|
|
if (pageNum == null) {
|
pageNum = 1;
|
}
|
|
if (pageSize == null) {
|
pageSize = 10;
|
}
|
|
if (APPLICANT == null) {
|
APPLICANT = "";
|
}
|
|
if (APPLICATIONBEGTIME == null) {
|
APPLICATIONBEGTIME = "";
|
}
|
|
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);
|
}
|
|
/**
|
* 导出报销申请列表
|
*/
|
@ApiOperation("导出报销申请列表")
|
//@PreAuthorize("@ss.hasPermi('project:reimbursement:export')")
|
@Log(title = "报销申请", businessType = BusinessType.EXPORT)
|
@GetMapping("/export")
|
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) {
|
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));
|
}
|
|
/**
|
* 往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));
|
}
|
|
/**
|
* 新增报销申请
|
*/
|
@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) {
|
|
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 = null;
|
if (nType == 1) {
|
remShare = new ServiceReimbursementShared();
|
remShare.setReimid(serviceReimbursement.getId());
|
} else //modify
|
{
|
List<ServiceReimbursementShared> remlist = serviceReimbursementServiceShare.getRemShareInfoByRemId(serviceReimbursement.getId());
|
if (remlist != null)
|
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;
|
LoginUser loginUser = getLoginUser();
|
SysUser user = loginUser.getUser();
|
List<Integer> postids = postService.selectPostListByUserId(loginUser.getUserId());
|
|
if (!postids.contains(2)) {
|
serviceReimbursement.setFlowlevel(1L);
|
serviceReimbursement.setRecordstatus(2);
|
} else {
|
serviceReimbursement.setFlowlevel(0L);
|
serviceReimbursement.setRecordstatus(0);
|
}
|
|
if (!postids.contains(2)) {
|
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) {
|
ServiceReimbursement serviceReimbursement = serviceReimbursementService.getById(checkFundVO.getFundid());
|
if (serviceReimbursement != null) {
|
Integer TotalLevel = 0;
|
LoginUser loginUser = getLoginUser();
|
ServiceFundflowrule serviceFundflowrule = new ServiceFundflowrule();
|
serviceFundflowrule.setFundtype(1);
|
serviceFundflowrule.setApplytype("0");
|
serviceFundflowrule.setCheckuserno(loginUser.getUsername());
|
List<ServiceFundflowrule> serviceFundflowrules = serviceFundflowruleService.queryList(serviceFundflowrule);
|
|
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());
|
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;
|
}
|
}
|
FlowLevel = FlowLevel + 1;
|
} else {
|
CheckFlag = 2;
|
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);
|
serviceFundflow.setFlowcontent(checkFundVO.getFlowcontent());
|
serviceFundflow.setFlowlevel(OriginalFlowLevel + 1);
|
serviceFundflowService.save(serviceFundflow);
|
|
List<Integer> postids = postService.selectPostListByUserId(loginUser.getUserId());
|
|
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());
|
serviceFundflowAuto.setFundtype(1);
|
serviceFundflowAuto.setApplytype("0");
|
serviceFundflowAuto.setFlowconclusion(CheckFlag);
|
serviceFundflowAuto.setFlowcontent("非专职人员二级审核拒绝后直接退回到修改状态");
|
serviceFundflowAuto.setFlowlevel(1);
|
serviceFundflowService.save(serviceFundflowAuto);
|
|
serviceReimbursement.setRecordstatus(1);
|
}
|
}
|
|
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());
|
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) + "级审核驳回,原因为" + 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)
|
@PutMapping
|
@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);
|
}
|
|
/**
|
* 删除报销申请
|
*/
|
@ApiOperation("删除报销申请")
|
//@PreAuthorize("@ss.hasPermi('project:reimbursement:remove')")
|
@Log(title = "报销申请", businessType = BusinessType.DELETE)
|
@DeleteMapping("/{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();
|
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("XM") + "_" + 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<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);
|
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);
|
}
|
}
|
|
|
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", 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", rdInfoByItem.get(0).getAmountrequested());
|
dataMap.put("JEXS", allMoney);
|
//double temp = 0;
|
//temp = Math.round(serviceReimbursement.getAmountrequested() * 100) * 0.01d;
|
// dataMap.put("JEDS", convert(rdInfoByItem.get(0).getAmountrequested().doubleValue()) + "整");
|
dataMap.put("JEDS", convert(allMoney.doubleValue()) + "整");
|
|
String remark = "";
|
for (ServiceReimbursementpayee serviceReimbursementpayee : reimbursementpayeeInfo) {
|
remark += "<w:br/> "+PersonType.getInfoByCode(serviceReimbursementpayee.getPersontype())+ "(" + serviceReimbursementpayee.getPersonname() + " " + serviceReimbursementpayee.getAmount();
|
remark += " 元; " + serviceReimbursementpayee.getBankname() + ": " + serviceReimbursementpayee.getBankcardno() + ") 备注: " + serviceReimbursementpayee.getRemark();
|
}
|
dataMap.put("BXBZ", remark);
|
|
|
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<ServiceReimbursementdetail> rd = serviceReimbursementdetailService.getAllDetailsByRBID(id);
|
if (rd == null) {
|
throw new ServiceException("下载失败,没有对应信息", HttpStatus.NO_CONTENT);
|
}
|
List<Map<String, Object>> newsList = new ArrayList<Map<String, Object>>();
|
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<String, Object> map = new HashMap<String, Object>();
|
|
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();
|
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);
|
|
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;
|
}
|
|
|
}
|