| | |
| | | package com.ruoyi.project.service.impl; |
| | | |
| | | import java.util.ArrayList; |
| | | import java.util.List; |
| | | |
| | | import com.ruoyi.project.domain.BaseExpertfeetype; |
| | | import com.ruoyi.project.domain.ServiceFunddetail; |
| | | import com.ruoyi.project.domain.ServiceReimbursement; |
| | | import com.ruoyi.project.domain.vo.*; |
| | | import com.ruoyi.project.mapper.BaseExpertfeetypeMapper; |
| | | import com.ruoyi.project.mapper.ServiceFunddetailMapper; |
| | | import com.ruoyi.project.mapper.ServiceReimbursementMapper; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | import com.alibaba.fastjson.JSON; |
| | | import com.alibaba.fastjson.JSONArray; |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | | import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.ruoyi.common.config.RuoYiConfig; |
| | | import com.ruoyi.common.core.domain.AjaxResult; |
| | | import com.ruoyi.common.exception.base.BaseException; |
| | | import com.ruoyi.common.utils.HttpClientKit; |
| | | import com.ruoyi.common.utils.StringUtils; |
| | | import com.ruoyi.project.mapper.ServiceFundMapper; |
| | | import com.ruoyi.project.domain.ServiceFund; |
| | | import com.ruoyi.project.service.IServiceFundService; |
| | | import com.ruoyi.common.utils.bean.DtoConversionUtils; |
| | | import com.ruoyi.common.utils.poi.ExcelUtil; |
| | | import com.ruoyi.project.domain.*; |
| | | import com.ruoyi.project.domain.vo.*; |
| | | import com.ruoyi.project.mapper.*; |
| | | import com.ruoyi.project.service.*; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.apache.commons.lang3.ObjectUtils; |
| | | import org.apache.ibatis.annotations.Param; |
| | | import org.apache.poi.ss.usermodel.*; |
| | | import org.apache.poi.xssf.usermodel.XSSFColor; |
| | | import org.apache.poi.xssf.usermodel.XSSFWorkbook; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import org.springframework.util.CollectionUtils; |
| | | |
| | | import java.io.File; |
| | | import java.io.FileInputStream; |
| | | import java.io.FileOutputStream; |
| | | import java.io.InputStream; |
| | | import java.math.BigDecimal; |
| | | import java.text.SimpleDateFormat; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | | |
| | | /** |
| | | * 费用申请主Service业务层处理 |
| | | * |
| | | * |
| | | * @author ruoyi |
| | | * @date 2022-01-24 |
| | | */ |
| | | @Slf4j |
| | | @Service |
| | | public class ServiceFundServiceImpl extends ServiceImpl<ServiceFundMapper, ServiceFund> implements IServiceFundService |
| | | { |
| | | public class ServiceFundServiceImpl extends ServiceImpl<ServiceFundMapper, ServiceFund> implements IServiceFundService { |
| | | @Autowired |
| | | ServiceFundMapper serviceFundMapper; |
| | | |
| | |
| | | @Autowired |
| | | ServiceReimbursementMapper serviceReimbursementMapper; |
| | | |
| | | @Autowired |
| | | IServiceFundSharedService sharedService; |
| | | |
| | | @Autowired |
| | | ServiceFundSharedMapper serviceFundSharedMapper; |
| | | |
| | | @Autowired |
| | | ServiceFunddetailSharedMapper sharedMapper; |
| | | |
| | | @Autowired |
| | | IServiceFunddetailSharedService detailSharedService; |
| | | |
| | | @Autowired |
| | | private IServiceFunddetailService serviceFunddetailService; |
| | | |
| | | @Autowired |
| | | private VExpertfeeExpertMapper vExpertfeeExpertMapper; |
| | | |
| | | @Autowired |
| | | private VExpertfeeDonorMapper vExpertfeeDonorMapper; |
| | | |
| | | @Autowired |
| | | private VExpertfeeTotalMapper vExpertfeeTotalMapper; |
| | | |
| | | |
| | | /** |
| | | * 查询费用申请主列表 |
| | | * |
| | | * 查询费用申请主列表(包含删除的) |
| | | * |
| | | * @param serviceFund 费用申请主 |
| | | * @return 费用申请主 |
| | | */ |
| | | @Override |
| | | public List<ServiceFund> queryList(ServiceFund serviceFund) { |
| | | LambdaQueryWrapper<ServiceFund> wrappers = Wrappers.lambdaQuery(); |
| | | if (StringUtils.isNotBlank(serviceFund.getDonorno())){ |
| | | wrappers.eq(ServiceFund::getDonorno ,serviceFund.getDonorno()); |
| | | if (StringUtils.isNotBlank(serviceFund.getDonorno())) { |
| | | wrappers.eq(ServiceFund::getDonorno, serviceFund.getDonorno()); |
| | | } |
| | | if (StringUtils.isNotBlank(serviceFund.getUserno())){ |
| | | wrappers.eq(ServiceFund::getUserno ,serviceFund.getUserno()); |
| | | if (serviceFund.getId() != null) { |
| | | wrappers.eq(ServiceFund::getId, serviceFund.getId()); |
| | | } |
| | | if (StringUtils.isNotBlank(serviceFund.getUsername())){ |
| | | wrappers.like(ServiceFund::getUsername ,serviceFund.getUsername()); |
| | | if (serviceFund.getFundTaxId() != null) { |
| | | wrappers.eq(ServiceFund::getFundTaxId, serviceFund.getFundTaxId()); |
| | | } |
| | | if (StringUtils.isNotBlank(serviceFund.getApplytype())){ |
| | | wrappers.eq(ServiceFund::getApplytype ,serviceFund.getApplytype()); |
| | | if (StringUtils.isNotBlank(serviceFund.getUserno())) { |
| | | wrappers.eq(ServiceFund::getUserno, serviceFund.getUserno()); |
| | | } |
| | | if (StringUtils.isNotBlank(serviceFund.getDeptmentname())){ |
| | | wrappers.like(ServiceFund::getDeptmentname ,serviceFund.getDeptmentname()); |
| | | if (StringUtils.isNotBlank(serviceFund.getUsername())) { |
| | | wrappers.like(ServiceFund::getUsername, serviceFund.getUsername()); |
| | | } |
| | | if (serviceFund.getRecordstatus()!= null){ |
| | | wrappers.eq(ServiceFund::getRecordstatus ,serviceFund.getRecordstatus()); |
| | | if (StringUtils.isNotBlank(serviceFund.getApplytype())) { |
| | | wrappers.eq(ServiceFund::getApplytype, serviceFund.getApplytype()); |
| | | } |
| | | if (StringUtils.isNotBlank(serviceFund.getUploadflag())){ |
| | | wrappers.eq(ServiceFund::getUploadflag ,serviceFund.getUploadflag()); |
| | | if (StringUtils.isNotBlank(serviceFund.getDeptmentname())) { |
| | | wrappers.like(ServiceFund::getDeptmentname, serviceFund.getDeptmentname()); |
| | | } |
| | | if (serviceFund.getUploadtime() != null){ |
| | | wrappers.eq(ServiceFund::getUploadtime ,serviceFund.getUploadtime()); |
| | | if (serviceFund.getRecordstatus() != null) { |
| | | wrappers.eq(ServiceFund::getRecordstatus, serviceFund.getRecordstatus()); |
| | | } |
| | | if (StringUtils.isNotBlank(serviceFund.getUploadflag())) { |
| | | wrappers.eq(ServiceFund::getUploadflag, serviceFund.getUploadflag()); |
| | | } |
| | | if (serviceFund.getUploadtime() != null) { |
| | | wrappers.eq(ServiceFund::getUploadtime, serviceFund.getUploadtime()); |
| | | } |
| | | if (serviceFund.getUploadStates() != null) { |
| | | wrappers.eq(ServiceFund::getUploadStates, serviceFund.getUploadStates()); |
| | | } |
| | | if (serviceFund.getFlowlevel() != null) { |
| | | wrappers.eq(ServiceFund::getFlowlevel, serviceFund.getFlowlevel()); |
| | | } |
| | | if (serviceFund.getJxrq() != null) { |
| | | wrappers.eq(ServiceFund::getJxrq, serviceFund.getJxrq()); |
| | | } |
| | | return this.list(wrappers); |
| | | } |
| | | |
| | | |
| | | @Override |
| | | public List<ServiceFund> queryInfoById(ServiceFund serviceFund) { |
| | | LambdaQueryWrapper<ServiceFund> wrappers = Wrappers.lambdaQuery(); |
| | | if (serviceFund.getId() != null) { |
| | | wrappers.eq(ServiceFund::getId, serviceFund.getId()); |
| | | } |
| | | |
| | | wrappers.eq(ServiceFund::getDel_flag, "0"); |
| | | return this.list(wrappers); |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | |
| | | |
| | | @Override |
| | | public Long getFundId(Long infoid) { |
| | | return serviceFundMapper.getFundId(infoid); |
| | | } |
| | | |
| | | @Override |
| | | public List<ServiceFund> selectServiceFundList(ServiceFund serviceFund) { |
| | | return serviceFundMapper.selectServiceFundList(serviceFund); |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public Boolean addFundSharedInfo(Long id) { |
| | | log.info("fund表的id:{}", id); |
| | | //判断一下,share表是否已经存在了 |
| | | Map<String, Object> map = new HashMap<>(); |
| | | map.put("serfunid", id); |
| | | map.put("del_flag", 0); |
| | | List<ServiceFundShared> serviceFundSharedList = serviceFundSharedMapper.selectByMap(map); |
| | | if (!CollectionUtils.isEmpty(serviceFundSharedList)) { |
| | | return true; |
| | | } |
| | | |
| | | ServiceFund serviceFund = serviceFundMapper.selectById(id); |
| | | ServiceFundShared serviceFundShared = DtoConversionUtils.sourceToTarget(serviceFund, ServiceFundShared.class); |
| | | serviceFundShared.setSerfunid(serviceFundShared.getId()); |
| | | serviceFundShared.setId(null); |
| | | log.info("数据都插进去了吗? {}", serviceFundShared); |
| | | sharedService.save(serviceFundShared); |
| | | |
| | | //fundId为主表的ID |
| | | Map<String, Object> columnMap = new HashMap<>(); |
| | | columnMap.put("fundid", id); |
| | | List<ServiceFunddetail> serviceFunddetails = serviceFunddetailMapper.selectByMap(columnMap); |
| | | //将查出的数据放到ServiceFunddetailShared中 |
| | | List<ServiceFunddetailShared> serviceFunddetailShareds = DtoConversionUtils.sourceToTarget(serviceFunddetails, ServiceFunddetailShared.class); |
| | | for (int i = 0; i < serviceFunddetails.size(); i++) { |
| | | serviceFunddetailShareds.get(i).setFdid(serviceFunddetailShareds.get(i).getId()); |
| | | //fundID为service_fund_shared表的主键ID |
| | | serviceFunddetailShareds.get(i).setFundid(serviceFundShared.getId()); |
| | | serviceFunddetailShareds.get(i).setId(null); |
| | | //数据发送给财务 |
| | | try { |
| | | uploadOAFileAndUpdateDb(serviceFunddetailShareds.get(i)); |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | | log.error("Exception中入参的ID为:{},异常信息为 : {}", id, e.getMessage()); |
| | | if (id != null) { |
| | | Boolean aBoolean = sharedService.delfundsharedInfoById(null, id); |
| | | log.error("fund2分享表里的数据是否删除成功:{}", aBoolean); |
| | | } |
| | | return false; |
| | | } |
| | | } |
| | | boolean result = false; |
| | | for (ServiceFunddetailShared serviceFunddetailShared : serviceFunddetailShareds) { |
| | | if (ObjectUtils.isNotEmpty(serviceFunddetailShared)) { |
| | | result = detailSharedService.save(serviceFunddetailShared); |
| | | } else { |
| | | log.info("serviceFunddetailShared为空了!!!"); |
| | | } |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | @Override |
| | | public List<ServiceFunddetail> getFundDetail(Long id) { |
| | | return serviceFunddetailMapper.selectFundDetailListById(id); |
| | | public List<ServiceFund> selectServiceFundList(ServiceFund serviceFund) { |
| | | return serviceFundMapper.selectServiceFundList(serviceFund); |
| | | } |
| | | |
| | | @Override |
| | |
| | | List<ServiceFund> serviceFunds = serviceFundMapper.getInfoByInfoId(infoid); |
| | | |
| | | List<ServiceFunddetail> fd = new ArrayList<>(); |
| | | for(ServiceFund s : serviceFunds){ |
| | | for (ServiceFund s : serviceFunds) { |
| | | List<ServiceFunddetail> l = serviceFunddetailMapper.getAllDetailsByFDIDHZ(s.getId()); |
| | | for(ServiceFunddetail df : l){ |
| | | for (ServiceFunddetail df : l) { |
| | | fd.add(df); |
| | | } |
| | | } |
| | |
| | | double sh52 = 0; |
| | | double shhj = 0; |
| | | |
| | | for(ServiceReimbursement sr : serviceReimbursements1){ |
| | | for (ServiceReimbursement sr : serviceReimbursements1) { |
| | | f28 += sr.getAmountrequested(); |
| | | sh28 += sr.getAmountrequested(); |
| | | } |
| | | for(ServiceReimbursement sr : serviceReimbursements2){ |
| | | for (ServiceReimbursement sr : serviceReimbursements2) { |
| | | f51 += sr.getAmountrequested(); |
| | | sh51 += sr.getAmountrequested(); |
| | | } |
| | | |
| | | for(ServiceFunddetail s : fd){ |
| | | if(s.getItemid() == 1){ |
| | | for (ServiceFunddetail s : fd) { |
| | | if (s.getItemid() == 1) { |
| | | f1 += s.getAmount(); |
| | | sh1 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 2){ |
| | | if (s.getItemid() == 2) { |
| | | f2 += s.getAmount(); |
| | | sh2 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 3){ |
| | | if (s.getItemid() == 3) { |
| | | f3 += s.getAmount(); |
| | | sh3 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 4){ |
| | | if (s.getItemid() == 4) { |
| | | f4 += s.getAmount(); |
| | | sh4 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 5){ |
| | | if (s.getItemid() == 5) { |
| | | f5 += s.getAmount(); |
| | | sh5 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 6){ |
| | | if (s.getItemid() == 6) { |
| | | f6 += s.getAmount(); |
| | | sh6 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 7){ |
| | | if (s.getItemid() == 7) { |
| | | f7 += s.getAmount(); |
| | | sh7 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 8){ |
| | | if (s.getItemid() == 8) { |
| | | f8 += s.getAmount(); |
| | | sh8 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 9){ |
| | | if (s.getItemid() == 9) { |
| | | f9 += s.getAmount(); |
| | | sh9 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 10){ |
| | | if (s.getItemid() == 10) { |
| | | f10 += s.getAmount(); |
| | | sh10 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 11){ |
| | | if (s.getItemid() == 11) { |
| | | f11 += s.getAmount(); |
| | | sh11 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 12){ |
| | | if (s.getItemid() == 12) { |
| | | f12 += s.getAmount(); |
| | | sh12 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 13){ |
| | | if (s.getItemid() == 13) { |
| | | f13 += s.getAmount(); |
| | | sh13 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 14){ |
| | | if (s.getItemid() == 14) { |
| | | f14 += s.getAmount(); |
| | | sh14 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 15){ |
| | | if (s.getItemid() == 15) { |
| | | f15 += s.getAmount(); |
| | | sh15 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 16){ |
| | | if (s.getItemid() == 16) { |
| | | f16 += s.getAmount(); |
| | | sh16 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 17){ |
| | | if (s.getItemid() == 17) { |
| | | f17 += s.getAmount(); |
| | | sh17 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 18){ |
| | | if (s.getItemid() == 18) { |
| | | f18 += s.getAmount(); |
| | | sh18 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 19){ |
| | | if (s.getItemid() == 19) { |
| | | f19 += s.getAmount(); |
| | | sh19 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 20){ |
| | | if (s.getItemid() == 20) { |
| | | f20 += s.getAmount(); |
| | | sh20 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 21){ |
| | | if (s.getItemid() == 21) { |
| | | f21 += s.getAmount(); |
| | | sh21 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 22){ |
| | | if (s.getItemid() == 22) { |
| | | f22 += s.getAmount(); |
| | | sh22 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 23){ |
| | | if (s.getItemid() == 23) { |
| | | f23 += s.getAmount(); |
| | | sh23 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 24){ |
| | | if (s.getItemid() == 24) { |
| | | f24 += s.getAmount(); |
| | | sh24 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 25){ |
| | | if (s.getItemid() == 25) { |
| | | f25 += s.getAmount(); |
| | | sh25 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 26){ |
| | | if (s.getItemid() == 26) { |
| | | f26 += s.getAmount(); |
| | | sh26 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 27){ |
| | | if (s.getItemid() == 27) { |
| | | f27 += s.getAmount(); |
| | | sh27 += s.getTaxedamount(); |
| | | } |
| | | |
| | | if(s.getItemid() == 29){ |
| | | if (s.getItemid() == 29) { |
| | | f29 += s.getAmount(); |
| | | sh29 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 30){ |
| | | if (s.getItemid() == 30) { |
| | | f30 += s.getAmount(); |
| | | sh30 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 31){ |
| | | if (s.getItemid() == 31) { |
| | | f31 += s.getAmount(); |
| | | sh31 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 32){ |
| | | if (s.getItemid() == 32) { |
| | | f32 += s.getAmount(); |
| | | sh32 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 33){ |
| | | if (s.getItemid() == 33) { |
| | | f33 += s.getAmount(); |
| | | sh33 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 34){ |
| | | if (s.getItemid() == 34) { |
| | | f34 += s.getAmount(); |
| | | sh34 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 35){ |
| | | if (s.getItemid() == 35) { |
| | | f35 += s.getAmount(); |
| | | sh35 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 36){ |
| | | if (s.getItemid() == 36) { |
| | | f36 += s.getAmount(); |
| | | sh36 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 37){ |
| | | if (s.getItemid() == 37) { |
| | | f37 += s.getAmount(); |
| | | sh37 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 38){ |
| | | if (s.getItemid() == 38) { |
| | | f38 += s.getAmount(); |
| | | sh38 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 39){ |
| | | if (s.getItemid() == 39) { |
| | | f39 += s.getAmount(); |
| | | sh39 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 40){ |
| | | if (s.getItemid() == 40) { |
| | | f40 += s.getAmount(); |
| | | sh40 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 41){ |
| | | if (s.getItemid() == 41) { |
| | | f41 += s.getAmount(); |
| | | sh41 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 42){ |
| | | if (s.getItemid() == 42) { |
| | | f42 += s.getAmount(); |
| | | sh42 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 43){ |
| | | if (s.getItemid() == 43) { |
| | | f43 += s.getAmount(); |
| | | sh43 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 44){ |
| | | if (s.getItemid() == 44) { |
| | | f44 += s.getAmount(); |
| | | sh44 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 45){ |
| | | if (s.getItemid() == 45) { |
| | | f45 += s.getAmount(); |
| | | sh45 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 46){ |
| | | if (s.getItemid() == 46) { |
| | | f46 += s.getAmount(); |
| | | sh46 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 47){ |
| | | if (s.getItemid() == 47) { |
| | | f47 += s.getAmount(); |
| | | sh47 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 48){ |
| | | if (s.getItemid() == 48) { |
| | | f48 += s.getAmount(); |
| | | sh48 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 49){ |
| | | if (s.getItemid() == 49) { |
| | | f49 += s.getAmount(); |
| | | sh49 += s.getTaxedamount(); |
| | | } |
| | | |
| | | if(s.getItemid() == 50){ |
| | | if (s.getItemid() == 50) { |
| | | f50 += s.getAmount(); |
| | | sh50 += s.getTaxedamount(); |
| | | } |
| | | if(s.getItemid() == 52){ |
| | | if (s.getItemid() == 52) { |
| | | f52 += s.getAmount(); |
| | | sh52 += s.getTaxedamount(); |
| | | } |
| | | } |
| | | |
| | | hj = f1 + f2 + f3 + f4 + f5 + f6 + f7 + f8 + f9 + f10 + f11 + f12 + f13 + f14 + f15 + f16 + f17 + f18 + f19 + f20 + f21 + f22 + f23 + f24 + f25 + f26 + f27 + f28 + f29 + f30 + f31 + f32 + f33 + f34 + f35 |
| | | + f36 + f37 + f38 + f39 + f40 + f41 + f42 + f43 + f44 + f45 + f46 + f47 + f48 + f49 + f50 + f51 + f52; |
| | | hj = f1 + f2 + f3 + f4 + f5 + f6 + f7 + f8 + f9 + f10 + f11 + f12 + f13 + f14 + f15 + f16 + f17 + f18 + f19 + f20 + f21 + f22 + f23 + f24 + f25 + f26 + f27 + f28 + f29 + f30 + f31 + f32 + f33 + f34 + f35 + f36 + f37 + f38 + f39 + f40 + f41 + f42 + f43 + f44 + f45 + f46 + f47 + f48 + f49 + f50 + f51 + f52; |
| | | |
| | | shhj = sh1 + sh2 + sh3 + sh4 + sh5 + sh6 + sh7 + sh8 + sh9 + sh10 + sh11 + sh12 + sh13 + sh14 + sh15 + sh16 + sh17 + sh18 + sh19 + sh20 + sh21 + sh22 + sh23 + sh24 + sh25 + sh26 + sh27 + sh28 + sh29 + sh30 + sh31 + sh32 + sh33 + sh34 + sh35 |
| | | + sh36 + sh37 + sh38 + sh39 + sh40 + sh41 + sh42 + sh43 + sh44 + sh45 + sh46 + sh47 + sh48 + sh49 + sh50 + sh51 + sh52; |
| | | shhj = sh1 + sh2 + sh3 + sh4 + sh5 + sh6 + sh7 + sh8 + sh9 + sh10 + sh11 + sh12 + sh13 + sh14 + sh15 + sh16 + sh17 + sh18 + sh19 + sh20 + sh21 + sh22 + sh23 + sh24 + sh25 + sh26 + sh27 + sh28 + sh29 + sh30 + sh31 + sh32 + sh33 + sh34 + sh35 + sh36 + sh37 + sh38 + sh39 + sh40 + sh41 + sh42 + sh43 + sh44 + sh45 + sh46 + sh47 + sh48 + sh49 + sh50 + sh51 + sh52; |
| | | |
| | | fdvo.setFy1(f1); |
| | | fdvo.setFy2(f2); |
| | |
| | | } |
| | | |
| | | @Override |
| | | public List<SpFinancialExpensesFundOut> getListBypower(String PAUSERNO, Integer PAFUNDTYPE, String PAAPPLICANT, String PAAPPLICATIONBEGTIME, String PAAPPLICATIONENDTIME, String PADEPARTMENT,Integer CHECKFLAG,Integer APPLYTYPE) { |
| | | return serviceFundMapper.getListBypower(PAUSERNO, PAFUNDTYPE, PAAPPLICANT, PAAPPLICATIONBEGTIME, PAAPPLICATIONENDTIME, PADEPARTMENT,CHECKFLAG,APPLYTYPE); |
| | | public List<SpFinancialExpensesFundOut> getListBypower(String PAUSERNO, Integer PAFUNDTYPE, String PAAPPLICANT, String PAAPPLICATIONBEGTIME, String PAAPPLICATIONENDTIME, String PADEPARTMENT, Integer CHECKFLAG, Integer APPLYTYPE, Integer CHECKSTATUS, String donorname) { |
| | | return serviceFundMapper.getListBypower(PAUSERNO, PAFUNDTYPE, PAAPPLICANT, PAAPPLICATIONBEGTIME, PAAPPLICATIONENDTIME, PADEPARTMENT, CHECKFLAG, APPLYTYPE, CHECKSTATUS, donorname); |
| | | } |
| | | |
| | | @Override |
| | | public List<SpFinancialExpensesFundOut> getExpertfeeList(SpSelectExpertfee spSelectExpertfee) { |
| | | return serviceFundMapper.getExpertfeeList(spSelectExpertfee.getPaApplyType(), spSelectExpertfee.getDonorname(), spSelectExpertfee.getPacheckno(), spSelectExpertfee.getCheckstatus(), spSelectExpertfee.getPadepartno(), spSelectExpertfee.getPausername()); |
| | | } |
| | | |
| | | @Override |
| | | public int countItem(Long infoid, Long itemid) { |
| | | List<ServiceFund> serviceFunds = serviceFundMapper.getInfoByInfoId(infoid); |
| | | |
| | | int count = 0; |
| | | for(ServiceFund s : serviceFunds){ |
| | | for (ServiceFund s : serviceFunds) { |
| | | long fundid = s.getId(); |
| | | int l = serviceFunddetailMapper.countItem(fundid, itemid); |
| | | count += l; |
| | |
| | | return count; |
| | | } |
| | | |
| | | @Override |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public Long addOrUpdateNew(ServiceFundVO serviceFundVO) { |
| | | Long id = null; |
| | | //将数据保存到fund表 |
| | | serviceFundVO.setUploadStates(0); |
| | | id = saveFund(serviceFundVO); |
| | | |
| | | List<ServiceFunddetailVO> serviceFunddetails = serviceFundVO.getServiceFunddetails(); |
| | | |
| | | BigDecimal bigDecimal = new BigDecimal(0.0); |
| | | if (!CollectionUtils.isEmpty(serviceFunddetails)) { |
| | | |
| | | // 保存详情数据 |
| | | for (ServiceFunddetailVO serviceFunddetailVO : serviceFunddetails) { |
| | | //去掉身份证的首尾空格 |
| | | if (StringUtils.isNotEmpty(serviceFunddetailVO.getIdcardno())) { |
| | | serviceFunddetailVO.setIdcardno(serviceFunddetailVO.getIdcardno().trim()); |
| | | } |
| | | |
| | | if (StringUtils.isEmpty(serviceFunddetailVO.getBankcardno())) { |
| | | throw new BaseException("请检查银行卡号是否为空,姓名:" + serviceFunddetailVO.getBeneficiaryname()); |
| | | } |
| | | serviceFunddetailVO.setFundid(id); |
| | | //將附件转成json |
| | | if (!CollectionUtils.isEmpty(serviceFunddetailVO.getAnnexfilesList())) { |
| | | serviceFunddetailVO.setAnnexfiles(JSON.toJSONString(serviceFunddetailVO.getAnnexfilesList())); |
| | | } else { |
| | | serviceFunddetailVO.setAnnexfiles(null); |
| | | } |
| | | if (!CollectionUtils.isEmpty(serviceFunddetailVO.getInvoicefilesList())) { |
| | | serviceFunddetailVO.setInvoicefiles(JSON.toJSONString(serviceFunddetailVO.getInvoicefilesList())); |
| | | } else { |
| | | serviceFunddetailVO.setInvoicefiles(null); |
| | | } |
| | | ServiceFunddetail serviceFunddetail = DtoConversionUtils.sourceToTarget(serviceFunddetailVO, ServiceFunddetail.class); |
| | | |
| | | if (serviceFunddetailVO.getId() == null) { |
| | | serviceFunddetailService.save(serviceFunddetail); |
| | | } else { |
| | | serviceFunddetailService.updateById(serviceFunddetail); |
| | | } |
| | | |
| | | bigDecimal = bigDecimal.add(BigDecimal.valueOf(serviceFunddetailVO.getAmount())); |
| | | |
| | | } |
| | | } |
| | | serviceFundVO.setPretaxcost(bigDecimal.doubleValue()); |
| | | serviceFundMapper.updateById(serviceFundVO); |
| | | return id; |
| | | } |
| | | |
| | | @Override |
| | | public Map<String, Long> performance(ServiceFundVO serviceFundVO) { |
| | | Long id = null; |
| | | //将数据保存到fund表 |
| | | id = saveFund(serviceFundVO); |
| | | |
| | | List<ServiceFunddetailVO> serviceFunddetails = serviceFundVO.getServiceFunddetails(); |
| | | if (CollectionUtils.isEmpty(serviceFunddetails)) { |
| | | System.out.println("serviceFunddetails为空喽"); |
| | | return null; |
| | | } |
| | | |
| | | //总税前 |
| | | Double pretaxcosts = 0.00; |
| | | //总税后 |
| | | Double taxedcosts = 0.00; |
| | | for (ServiceFunddetailVO serviceFunddetailVO : serviceFunddetails) { |
| | | serviceFunddetailVO.setFundid(id); |
| | | |
| | | ServiceFunddetail serviceFunddetail = DtoConversionUtils.sourceToTarget(serviceFunddetailVO, ServiceFunddetail.class); |
| | | Map<String, Double> performance = serviceFunddetailService.performance(serviceFunddetail); |
| | | if (!performance.isEmpty()) { |
| | | Double amount = performance.get("amount"); |
| | | Double taxedamount = performance.get("taxedamount"); |
| | | pretaxcosts = pretaxcosts + amount; |
| | | taxedcosts = taxedcosts + taxedamount; |
| | | } |
| | | serviceFundVO.setPretaxcost(pretaxcosts); |
| | | serviceFundVO.setTaxedcost(taxedcosts); |
| | | updateById(serviceFundVO); |
| | | } |
| | | Map map = new HashMap(); |
| | | map.put("fundId", id); |
| | | return map; |
| | | } |
| | | |
| | | @Override |
| | | public Map<String, List<ServiceFunddetailExcel>> totaltax(TotalTaxVO totalTaxVO) { |
| | | if (CollectionUtils.isEmpty(totalTaxVO.getFundids())) { |
| | | throw new BaseException("请勾选之后,再进行合计个税"); |
| | | } |
| | | Map<String, List<ServiceFunddetailExcel>> map = new HashMap<>(); |
| | | |
| | | if (totalTaxVO.getIsTaxAfter() == null) { |
| | | //如何为空,默认当没有算过税,进行合计 |
| | | totalTaxVO.setIsTaxAfter(0); |
| | | } |
| | | List<ServiceFunddetail> serviceFunddetails = serviceFunddetailMapper.totlaTax(totalTaxVO.getFundids()); |
| | | if (CollectionUtils.isEmpty(serviceFunddetails)) { |
| | | throw new BaseException("查询的详情数据为空"); |
| | | } |
| | | |
| | | //用于返回excel |
| | | List<ServiceFunddetailExcel> serviceFunddetailList = new ArrayList<>(); |
| | | |
| | | if (totalTaxVO.getIsTaxAfter() == 1) { |
| | | //通过受益人名称,将税前、税后的值相加 |
| | | Map<String, Double> sumAmount = serviceFunddetails.stream().collect(Collectors.groupingBy(ServiceFunddetail::getBeneficiaryname, Collectors.summingDouble(ServiceFunddetail::getAmount))); |
| | | Map<String, Double> sumTaxdAmount = serviceFunddetails.stream().collect(Collectors.groupingBy(ServiceFunddetail::getBeneficiaryname, Collectors.summingDouble(ServiceFunddetail::getTaxedamount))); |
| | | |
| | | for (String key : sumAmount.keySet()) { |
| | | ServiceFunddetailExcel serviceFunddetailExcel = new ServiceFunddetailExcel(); |
| | | serviceFunddetailExcel.setAmount(sumAmount.getOrDefault(key, 0.0)); |
| | | serviceFunddetailExcel.setTaxedamount(sumTaxdAmount.getOrDefault(key, 0.0)); |
| | | for (ServiceFunddetail serviceFunddetail2 : serviceFunddetails) { |
| | | if (serviceFunddetail2.getBeneficiaryname().equals(key)) { |
| | | serviceFunddetailExcel.setIdcardno(serviceFunddetail2.getIdcardno()); |
| | | serviceFunddetailExcel.setBankcardno(serviceFunddetail2.getBankcardno()); |
| | | serviceFunddetailExcel.setBeneficiaryname(serviceFunddetail2.getBeneficiaryname()); |
| | | serviceFunddetailExcel.setDepositbank(serviceFunddetail2.getDepositbank()); |
| | | serviceFunddetailExcel.setBranchbankname(serviceFunddetail2.getBranchbankname()); |
| | | serviceFunddetailExcel.setDonorname(serviceFunddetail2.getDonorname()); |
| | | serviceFunddetailExcel.setPhone(serviceFunddetail2.getPhone()); |
| | | break; |
| | | } |
| | | } |
| | | serviceFunddetailList.add(serviceFunddetailExcel); |
| | | } |
| | | //返回算过税之后的,合计 |
| | | map.put("合计个税(税后)", serviceFunddetailList); |
| | | return map; |
| | | |
| | | } else { |
| | | a: |
| | | for (ServiceFunddetail serviceFunddetail : serviceFunddetails) { |
| | | ServiceFunddetailExcel sfeBefore = new ServiceFunddetailExcel(); |
| | | ServiceFunddetailExcel sfeAfter = new ServiceFunddetailExcel(); |
| | | |
| | | for (ServiceFunddetailExcel serviceFunddetailExcel : serviceFunddetailList) { |
| | | //判断一下,该受益人是否已经计算过,已经计算过了,就不算了 |
| | | if (serviceFunddetail.getBeneficiaryname().trim().equals(serviceFunddetailExcel.getBeneficiaryname().trim())) { |
| | | continue a; |
| | | } |
| | | } |
| | | |
| | | |
| | | for (ServiceFunddetail serviceFunddetail2 : serviceFunddetails) { |
| | | if (StringUtils.isEmpty(serviceFunddetail2.getServicesscopename())) { |
| | | ServiceFund serviceFund = null; |
| | | if (serviceFunddetail2.getFundid() == null) { |
| | | serviceFund = serviceFundMapper.selectById(serviceFunddetail2.getFundid()); |
| | | } |
| | | throw new BaseException("服务说明为空,请检查后再计算,捐献者为 :" + serviceFund.getDonorname()); |
| | | } |
| | | if (serviceFunddetail.getBeneficiaryname().equals(serviceFunddetail2.getBeneficiaryname()) && !(serviceFunddetail2.getServicesscopename().equals("税后"))) { |
| | | //累计税前 |
| | | sfeBefore.setIdcardno(serviceFunddetail2.getIdcardno()); |
| | | sfeBefore.setBankcardno(serviceFunddetail2.getBankcardno()); |
| | | sfeBefore.setBeneficiaryname(serviceFunddetail2.getBeneficiaryname()); |
| | | sfeBefore.setDepositbank(serviceFunddetail2.getDepositbank()); |
| | | sfeBefore.setBranchbankname(serviceFunddetail2.getBranchbankname()); |
| | | sfeBefore.setDonorname(serviceFunddetail2.getDonorname()); |
| | | sfeBefore.setPhone(serviceFunddetail2.getPhone()); |
| | | if (sfeBefore.getAmount() == null) { |
| | | sfeBefore.setAmount(serviceFunddetail2.getAmount()); |
| | | } else { |
| | | sfeBefore.setAmount(sfeBefore.getAmount() + serviceFunddetail2.getAmount()); |
| | | } |
| | | sfeBefore.setTaxedamount(null); |
| | | |
| | | } else if (serviceFunddetail.getBeneficiaryname().equals(serviceFunddetail2.getBeneficiaryname()) && serviceFunddetail2.getServicesscopename().equals("税后")) { |
| | | //累计税后 |
| | | sfeAfter.setIdcardno(serviceFunddetail2.getIdcardno()); |
| | | sfeAfter.setBankcardno(serviceFunddetail2.getBankcardno()); |
| | | sfeAfter.setBeneficiaryname(serviceFunddetail2.getBeneficiaryname()); |
| | | sfeAfter.setDepositbank(serviceFunddetail2.getDepositbank()); |
| | | sfeAfter.setBranchbankname(serviceFunddetail2.getBranchbankname()); |
| | | sfeAfter.setDonorname(serviceFunddetail2.getDonorname()); |
| | | sfeAfter.setPhone(serviceFunddetail2.getPhone()); |
| | | sfeAfter.setAmount(null); |
| | | if (sfeAfter.getTaxedamount() == null) { |
| | | sfeAfter.setTaxedamount(serviceFunddetail2.getTaxedamount()); |
| | | } else { |
| | | sfeAfter.setTaxedamount(sfeAfter.getTaxedamount() + serviceFunddetail2.getTaxedamount()); |
| | | } |
| | | } |
| | | |
| | | } |
| | | //将计算好的税前总值、税后总值,放到List中 |
| | | if (ObjectUtils.isNotEmpty(sfeBefore.getBeneficiaryname())) serviceFunddetailList.add(sfeBefore); |
| | | |
| | | if (ObjectUtils.isNotEmpty(sfeAfter.getBeneficiaryname())) serviceFunddetailList.add(sfeAfter); |
| | | |
| | | } |
| | | //返回算税之前的,合计 |
| | | map.put("合计个税(税前)", serviceFunddetailList); |
| | | return map; |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | public Map<String, Object> exportFeeSum(Integer faxId) { |
| | | List<VExpertfeeTotal> list = vExpertfeeTotalMapper.selectVExpertfeeTotalListByTaxId(faxId); |
| | | ExcelUtil<VExpertfeeTotal> util = new ExcelUtil<VExpertfeeTotal>(VExpertfeeTotal.class); |
| | | AjaxResult ajaxResult = util.exportExcel(list, "vExpertfeeTotal"); |
| | | String filePath = RuoYiConfig.getDownloadPath() + ajaxResult.get("msg"); |
| | | |
| | | List<VExpertfeeDonor> list2 = vExpertfeeDonorMapper.selectVExpertfeeDonorList2(faxId); |
| | | ExcelUtil<VExpertfeeDonor> util2= new ExcelUtil<VExpertfeeDonor>(VExpertfeeDonor.class); |
| | | AjaxResult ajaxResult2 = util2.exportExcel(list2, "VExpertfeeDonor"); |
| | | |
| | | List<VExpertfeeExpert> list3 = vExpertfeeExpertMapper.selectVExpertfeeExpertListByFaxId(faxId); |
| | | ExcelUtil<VExpertfeeExpert> util3 = new ExcelUtil<VExpertfeeExpert>(VExpertfeeExpert.class); |
| | | AjaxResult ajaxResult3 = util3.exportExcel(list3, "vExpertfeeExpert"); |
| | | |
| | | List<String> list1 = new ArrayList<>(); |
| | | list1.add(ajaxResult.get("msg").toString()); |
| | | list1.add(ajaxResult2.get("msg").toString()); |
| | | list1.add(ajaxResult3.get("msg").toString()); |
| | | |
| | | |
| | | String name = "专家费汇总单" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()) + ".xlsx"; |
| | | mergeExcel(list1, RuoYiConfig.getDownloadPath() + name); |
| | | for (String path : list1) { |
| | | new File(RuoYiConfig.getDownloadPath() + path).delete(); |
| | | } |
| | | Map<String, Object> map = new HashMap<>(); |
| | | map.put("downloadUrl", "/profile/download/" + name); |
| | | map.put("downloadName", name); |
| | | return map; |
| | | } |
| | | |
| | | |
| | | int uploadOAFileAndUpdateDb(ServiceFunddetailShared remShare) throws Exception { |
| | | //上传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(); |
| | | |
| | | String filePath = RuoYiConfig.getUploadPath(); |
| | | String strFUrl = "http://129.88.242.39:8899/seeyon/rest/attachment?token=" + strRes; |
| | | List<RbDetailFile> parseArray2 = new ArrayList<>(); |
| | | List<RbDetailFile> invoicefilesList = new ArrayList<>(); |
| | | |
| | | //普通附件 |
| | | List<RbDetailFile> parseArray = JSON.parseArray(remShare.getAnnexfiles(), RbDetailFile.class); |
| | | //发票附件 |
| | | List<RbDetailFile> invoicefilesArray = JSON.parseArray(remShare.getInvoicefiles(), RbDetailFile.class); |
| | | log.info("parseArray的值 : {}, invoicefilesArray的值 : {},", parseArray, invoicefilesArray); |
| | | |
| | | //普通附件 |
| | | uploadFile(filePath, strFUrl, parseArray2, parseArray, remShare, "1"); |
| | | |
| | | //发票附件 |
| | | uploadFile(filePath, strFUrl, invoicefilesList, invoicefilesArray, remShare, "2"); |
| | | return 0; |
| | | } |
| | | |
| | | |
| | | private Integer uploadFile(String filePath, String strFUrl, List<RbDetailFile> parseArray2, List<RbDetailFile> parseArray, ServiceFunddetailShared remShare, String flag) throws Exception { |
| | | if (!CollectionUtils.isEmpty(parseArray)) { |
| | | for (int i = 0; i < parseArray.size(); i++) { |
| | | RbDetailFile rbDetailFile = parseArray.get(i); |
| | | log.info("filePath的修改:{}", filePath); |
| | | String url = rbDetailFile.getUrl(); |
| | | //file用的是绝对位置 |
| | | String substring = url.substring(url.indexOf("/profile/upload") + "/profile/upload".length()); |
| | | // String strFile = rbDetailFile.getUrl().replace(filePath, "/profile/upload"); |
| | | System.out.println("fund服务的filePath + substring: " + filePath + substring); |
| | | File filetest = new File(filePath + substring); |
| | | |
| | | String struploadResult = HttpClientKit.sendPostWithFile(filetest, strFUrl); |
| | | log.info("第三方传回的数据: {}", struploadResult); |
| | | if (StringUtils.isEmpty(struploadResult)) { |
| | | log.error("HttpClientKit.sendPostWithFile 请求为空了 filetest:{}, strFUrl:{} ", filetest, strFUrl); |
| | | return 0; |
| | | } |
| | | //获取fileid |
| | | JSONObject jsonR = JSONObject.parseObject(struploadResult); |
| | | JSONArray jsonArr = jsonR.getJSONArray("atts"); |
| | | log.info("第三方传回的数据获取的atts : {}", jsonArr); |
| | | for (int j = 0; j < jsonArr.size(); j++) { |
| | | JSONObject jsonRet = jsonArr.getJSONObject(j); |
| | | if (StringUtils.isEmpty(jsonRet.get("fileUrl").toString())) { |
| | | throw new BaseException("fileID为空,请联系第三方处理"); |
| | | } |
| | | rbDetailFile.setFileid(jsonRet.get("fileUrl").toString()); |
| | | } |
| | | |
| | | parseArray2.add(rbDetailFile); |
| | | } |
| | | if (flag.equals("1")) { |
| | | //如果flag为1,则是普通 |
| | | remShare.setAnnexfiles(JSON.toJSONString(parseArray2)); |
| | | } else if (flag.equals("2")) { |
| | | //如果flag为2,则是发票 |
| | | remShare.setInvoicefiles(JSON.toJSONString(parseArray2)); |
| | | } |
| | | log.info("ServiceReimbursementdetailShared 是否加上了fileid : {}", remShare); |
| | | } |
| | | return 0; |
| | | } |
| | | |
| | | // int uploadOAFileAndUpdateDb(ServiceFundShared remShare) { |
| | | // //上传OA文件 |
| | | // //String strUrl = "http://129.88.242.39:8899/seeyon/rest/token?userName=opo&password=127814f8-84e8-4304-84a5-a71573567efd&loginName=demo3"; |
| | | // String strUrl = "http://129.88.242.39:8899/seeyon/rest/token"; |
| | | // //String strUrl = "http://slb.hospitalstar.com:8899/seeyon/rest/token"; |
| | | // //上传文件成功后,去更新相关的数据库 |
| | | // |
| | | // |
| | | // Map<String, Object> map = new HashMap<String, Object>(); |
| | | // map.put("userName", "opo"); |
| | | // map.put("password", "4126407a-9821-4874-be41-6568abd6dbe5"); |
| | | // map.put("loginName", "demo3"); |
| | | // |
| | | // JSONObject jsonObj = new JSONObject(map); |
| | | // |
| | | // System.out.println("uploadOAFileAndUpdateDb + jsonObject" + jsonObj.toString() + "\r\n" + jsonObj.toJSONString()); |
| | | // String strRes = HttpClientKit.postOpr(strUrl, jsonObj.toString());// |
| | | // //String strRes = HttpClientKit.postMsg(strUrl,jsonObj);//得到返回的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.getAnnexbankcard();//可能存在多个地址,以,分开 |
| | | // |
| | | // String strFUrl = "http://129.88.242.39:8899/seeyon/rest/attachment?token=" + strRes; |
| | | // //String strFUrl = "http://slb.hospitalstar.com:8899/seeyon/rest/attachment?token="+strRes; |
| | | // //strFUrl = String.format(strFUrl, strRes); |
| | | // |
| | | // /*File test = null; |
| | | // File file = new File("E:\\YYJQ\\OPO\\WEB\\Upload\\upload\\2023\\02\\17"); |
| | | // if (file.exists() && file.isDirectory()) { |
| | | // // 获取所有盲盒文件夹 |
| | | // File[] ones = file.listFiles(); |
| | | // for (File one : ones) { |
| | | // test = one; |
| | | // } |
| | | // }*/ |
| | | // |
| | | // String filename = ""; |
| | | // String fileid = ""; |
| | | // |
| | | // String[] urlArray = strMutfileUrl.split(","); |
| | | // for (int i = 0; i < urlArray.length; i++) { |
| | | // String strOneFileName = urlArray[i]; |
| | | // String strTemp = strOneFileName.substring(15); |
| | | // String strFile = filePath + strTemp; |
| | | // //FileUploadUtils.getAbsoluteFile(filePath,strOneFileName); |
| | | // String struploadResult = ""; |
| | | // File filetest = new File(strFile); |
| | | // try { |
| | | // struploadResult = HttpClientKit.sendPostWithFile(filetest, strFUrl); |
| | | // } catch (Exception e) { |
| | | // e.printStackTrace(); |
| | | // } |
| | | // |
| | | // |
| | | // //String strFRes = HttpClientKit.postMsg(strFUrl,jsonFObj); |
| | | // if (struploadResult == null) return 0; |
| | | // if (struploadResult.isEmpty()) return 0; |
| | | // |
| | | // JSONObject jsonR = JSONObject.parseObject(struploadResult); |
| | | // |
| | | // JSONArray jsonArr = jsonR.getJSONArray("atts"); |
| | | // for (int j = 0; j < jsonArr.size(); j++) { |
| | | // JSONObject jsonRet = jsonArr.getJSONObject(j); |
| | | // String name1 = jsonRet.get("filename").toString(); |
| | | // String id1 = jsonRet.get("fileUrl").toString(); |
| | | // filename += name1; |
| | | // fileid += id1; |
| | | // if (i != urlArray.length - 1) { |
| | | // filename += ","; |
| | | // fileid += ","; |
| | | // } |
| | | // } |
| | | // |
| | | // } |
| | | // |
| | | // long nId = remShare.getId(); |
| | | // remShare.setId(nId); |
| | | // remShare.setFilename(filename); |
| | | // remShare.setFileid(fileid); |
| | | // boolean bRet = sharedService.updateById(remShare); |
| | | // if (!bRet) return -1; |
| | | // |
| | | // return 0; |
| | | // } |
| | | |
| | | public long saveFund(ServiceFundVO serviceFundVO) { |
| | | Long id = null; |
| | | //将数据保存到fund表 |
| | | if (ObjectUtils.isNotEmpty(serviceFundVO) && serviceFundVO.getId() == null) { |
| | | serviceFundVO.setCheckstatus(serviceFundVO.getCheckstatus() == null ? 1 : 2); |
| | | save(serviceFundVO); |
| | | id = serviceFundVO.getId(); |
| | | } else { |
| | | updateById(serviceFundVO); |
| | | id = serviceFundVO.getId(); |
| | | } |
| | | return id; |
| | | } |
| | | |
| | | public void mergeExcel(List<String> files, String outputFile) { |
| | | try { |
| | | Workbook resultWorkbook = new XSSFWorkbook(); |
| | | for (String file : files) { |
| | | InputStream is1 = new FileInputStream(RuoYiConfig.getDownloadPath() + file); |
| | | Workbook workbook1 = new XSSFWorkbook(is1); |
| | | Sheet sheet1 = workbook1.getSheetAt(0); |
| | | // 复制第一个文件的Sheet |
| | | Sheet newSheet1 = resultWorkbook.createSheet(file.substring(0, file.indexOf("."))); |
| | | for (Row row : sheet1) { |
| | | Row newRow = newSheet1.createRow(row.getRowNum()); |
| | | int columns = row.getLastCellNum(); |
| | | for (int i = 0; i < columns; i++) { |
| | | newSheet1.setColumnWidth(i, 5000); |
| | | Cell cell = row.getCell(i); |
| | | Cell newCell = newRow.createCell(cell.getColumnIndex()); |
| | | newCell.setCellValue(cell.getStringCellValue()); |
| | | // 创建单元格样式 |
| | | CellStyle style = resultWorkbook.createCellStyle(); |
| | | style.setAlignment(HorizontalAlignment.CENTER); // 水平居中 |
| | | style.setVerticalAlignment(VerticalAlignment.CENTER); // 垂直居中 |
| | | if (row.getRowNum() == 0) { |
| | | // 设置第一行背景色 |
| | | style.setFillForegroundColor(IndexedColors.GREY_50_PERCENT.getIndex()); |
| | | style.setFillPattern(FillPatternType.SOLID_FOREGROUND); |
| | | } |
| | | |
| | | newCell.setCellStyle(style); |
| | | } |
| | | } |
| | | } |
| | | FileOutputStream out = new FileOutputStream(outputFile); |
| | | resultWorkbook.write(out); |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | | } |
| | | } |
| | | |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public Boolean updateFundTaxIdById(Long id, Long fundTaxId) { |
| | | return serviceFundMapper.updateFundTaxIdById(id, fundTaxId); |
| | | } |
| | | } |