Commit 68f20da1 authored by gary's avatar gary

Merge remote-tracking branch 'origin/dev_mysql' into dev_mysql

# Conflicts:
#	atms-web/src/main/webapp/app-resources/i18n/en-us/vat.json
parents dd42ff16 216bb2e0
...@@ -2,18 +2,14 @@ package pwc.taxtech.atms.common; ...@@ -2,18 +2,14 @@ package pwc.taxtech.atms.common;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException; import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.*; import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.List;
import java.util.Map;
import java.util.Optional; import java.util.Optional;
public class POIUtil { public class POIUtil {
...@@ -112,4 +108,17 @@ public class POIUtil { ...@@ -112,4 +108,17 @@ public class POIUtil {
return Optional.empty(); return Optional.empty();
} }
} }
public static Row createRow(Sheet sheet, Integer rowIndex) {
Row row = null;
if (sheet.getRow(rowIndex) != null) {
int lastRowNo = sheet.getLastRowNum();
sheet.shiftRows(rowIndex, lastRowNo, 1);
}
row = sheet.createRow(rowIndex);
return row;
}
} }
...@@ -10,7 +10,9 @@ public class FileUploadEnum { ...@@ -10,7 +10,9 @@ public class FileUploadEnum {
*/ */
public enum BizSource { public enum BizSource {
REPORT_UPLOAD("REPORT_UPLOAD", "历史报表归档上传"), REPORT_UPLOAD("REPORT_UPLOAD", "历史报表归档上传"),
RECORD_UPLOAD("RECORD_UPLOAD", "档案管理上传"); RECORD_UPLOAD("RECORD_UPLOAD", "档案管理上传"),
REPORT_TEMPLATE_UPLOAD("REPORT_TEMPLATE_UPLOAD", "报表模板上传"),
PERIOD_REPORT_TEMPLATE_UPLOAD("PERIOD_REPORT_TEMPLATE_UPLOAD", "期间报表模板上传"),;
private String code; private String code;
private String name; private String name;
public static final Map<String, String> MAPPING = new HashMap<>(); public static final Map<String, String> MAPPING = new HashMap<>();
......
package pwc.taxtech.atms.controller;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
import pwc.taxtech.atms.common.message.ErrorMessage;
import pwc.taxtech.atms.dto.OperationResultDto;
import pwc.taxtech.atms.exception.ServiceException;
import pwc.taxtech.atms.service.impl.DidiFileUploadService;
@RestController
@RequestMapping("/api/v1/DidiFileUpload")
public class DidiFileUploadController {
private static final Logger logger = LoggerFactory.getLogger(DidiFileUploadController.class);
@Autowired
private DidiFileUploadService didiFileUploadService;
@ResponseBody
// @ApiOperation(value = "导入模板")
@RequestMapping(value = "importTemplateGroupExcelFile", method = RequestMethod.POST)
public OperationResultDto uploadFile(@RequestParam MultipartFile file) {
try {
if (null == file) {
return OperationResultDto.error(ErrorMessage.NoFile);
}
return OperationResultDto.success();
} catch (ServiceException e) {
return OperationResultDto.error(e.getMessage());
} catch (Exception e) {
logger.error("uploadFile error.", e);
}
return OperationResultDto.error(ErrorMessage.SystemError);
}
// @PostMapping("queryPage")
// public CamelPagingResultDto<DidiFileUploadDetailResult> queryPage(@RequestBody DidiFileIUploadParam param) {
// return new CamelPagingResultDto<>(revenueDetailService.queryPage(param));
// }
}
...@@ -16,11 +16,21 @@ public class TemplateGroupDto { ...@@ -16,11 +16,21 @@ public class TemplateGroupDto {
private String copyFrom; private String copyFrom;
private String industryIds; private String industryIds;
private Integer payTaxType; private Integer payTaxType;
private Integer reportType;
private Integer groupType; private Integer groupType;
private Boolean isSystemType; private Boolean isSystemType;
private List<TemplateFormulaDto> changedFormulas; private List<TemplateFormulaDto> changedFormulas;
private List<String> sheetNameList; private List<String> sheetNameList;
public Integer getReportType() {
return reportType;
}
public void setReportType(Integer reportType) {
this.reportType = reportType;
}
public String getId() { public String getId() {
return id; return id;
} }
......
...@@ -122,6 +122,52 @@ public class DidiFileUploadService extends BaseService { ...@@ -122,6 +122,52 @@ public class DidiFileUploadService extends BaseService {
throw new ServiceException("uploadFile error."); throw new ServiceException("uploadFile error.");
} }
public FileUpload uploadFile(byte[] bytes, String fileName, String bizSource) throws ServiceException
{
CloseableHttpClient httpClient = null;
String requestKey = CommonUtils.getUUID();
String requestUrl = upload_post_url + "/" + requestKey;
FileUploadLog uploadLog = new FileUploadLog();
uploadLog.setRequestId(requestKey);
uploadLog.setRequestUrl(requestUrl);
uploadLog.setUid(CommonUtils.getUUID());
try {
httpClient = HttpClients.createDefault();
HttpPost httpPost = new HttpPost(requestUrl);
ByteArrayBody byteBody = new ByteArrayBody(bytes, ContentType.MULTIPART_FORM_DATA, fileName);
HttpEntity httpEntity = MultipartEntityBuilder.create().addPart("filecontent", byteBody).build();
httpPost.setEntity(httpEntity);
HttpResponse httpResponse = httpClient.execute(httpPost);
JSONObject resultDto = JSON.parseObject(IOUtils.toString(httpResponse.getEntity().getContent(), "UTF-8"));
uploadLog.setResponsJson(resultDto.toJSONString());
FileUpload fileUpload = null;
if (HTTP_SUCCESS_CODE.equals(resultDto.getString("status_code"))) {
fileUpload = new FileUpload();
fileUpload.setBizSource(bizSource);
fileUpload.setUid(CommonUtils.getUUID());
fileUpload.setFileName(fileName);
fileUpload.setResourceKey(requestKey);
assemblyModel(resultDto, fileUpload);
uploadLog.setFileUploadId(fileUpload.getUid());
fileUploadMapper.insert(fileUpload);
}
fileUploadLogMapper.insert(uploadLog);
return fileUpload;
} catch (Exception e) {
uploadLog.setResponsJson(e.getMessage());
fileUploadLogMapper.insert(uploadLog);
logger.error("uploadFile error.", e);
} finally {
if (null != httpClient) {
try {
httpClient.close();
} catch (IOException e) {
logger.error("close httpClient error.", e);
}
}
}
throw new ServiceException("uploadFile error.");
}
public static String getFileMD5String(MultipartFile file) throws Exception { public static String getFileMD5String(MultipartFile file) throws Exception {
MessageDigest messagedigest = MessageDigest.getInstance("MD5"); MessageDigest messagedigest = MessageDigest.getInstance("MD5");
messagedigest.update(file.getBytes()); messagedigest.update(file.getBytes());
......
...@@ -2,21 +2,16 @@ package pwc.taxtech.atms.service.impl; ...@@ -2,21 +2,16 @@ package pwc.taxtech.atms.service.impl;
import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import org.apache.commons.io.Charsets;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.commons.lang3.CharSet;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.apache.http.Consts;
import org.apache.http.HttpEntity; import org.apache.http.HttpEntity;
import org.apache.http.HttpHeaders; import org.apache.http.HttpHeaders;
import org.apache.http.HttpResponse; import org.apache.http.HttpResponse;
import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet; import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost; import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.BasicHttpEntity;
import org.apache.http.entity.ContentType; import org.apache.http.entity.ContentType;
import org.apache.http.entity.StringEntity; import org.apache.http.entity.StringEntity;
import org.apache.http.entity.mime.MultipartEntityBuilder;
import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients; import org.apache.http.impl.client.HttpClients;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
...@@ -30,10 +25,6 @@ import pwc.taxtech.atms.exception.ServiceException; ...@@ -30,10 +25,6 @@ import pwc.taxtech.atms.exception.ServiceException;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.nio.charset.StandardCharsets;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
/** /**
* version 2.0 * version 2.0
...@@ -112,7 +103,14 @@ public class HttpFileService extends BaseService { ...@@ -112,7 +103,14 @@ public class HttpFileService extends BaseService {
} }
if (StringUtils.isNotBlank(config.getServerUrl())) { if (StringUtils.isNotBlank(config.getServerUrl())) {
CloseableHttpClient client = HttpClients.createDefault(); CloseableHttpClient client = HttpClients.createDefault();
HttpGet httpGet = new HttpGet(StringUtils.appendIfMissing(config.getServerUrl(), "/") + filePath); //先判断下是否是全域名 全域名代表是didi服务器url
String url;
if(filePath.indexOf("http")>=0){
url = filePath;
}else{
url = StringUtils.appendIfMissing(config.getServerUrl(), "/") + filePath;
}
HttpGet httpGet = new HttpGet(url);
CloseableHttpResponse response = null; CloseableHttpResponse response = null;
try { try {
response = client.execute(httpGet); response = client.execute(httpGet);
......
...@@ -17,6 +17,7 @@ import pwc.taxtech.atms.common.message.ErrorMessage; ...@@ -17,6 +17,7 @@ import pwc.taxtech.atms.common.message.ErrorMessage;
import pwc.taxtech.atms.common.message.TemplateMessage; import pwc.taxtech.atms.common.message.TemplateMessage;
import pwc.taxtech.atms.constant.Constant; import pwc.taxtech.atms.constant.Constant;
import pwc.taxtech.atms.constant.enums.CellDataSourceType; import pwc.taxtech.atms.constant.enums.CellDataSourceType;
import pwc.taxtech.atms.constant.enums.FileUploadEnum;
import pwc.taxtech.atms.constant.enums.TemplateGroupType; import pwc.taxtech.atms.constant.enums.TemplateGroupType;
import pwc.taxtech.atms.dao.CellTemplateConfigDao; import pwc.taxtech.atms.dao.CellTemplateConfigDao;
import pwc.taxtech.atms.dao.CellTemplateConfigMapper; import pwc.taxtech.atms.dao.CellTemplateConfigMapper;
...@@ -38,6 +39,7 @@ import pwc.taxtech.atms.entity.TemplateGroup; ...@@ -38,6 +39,7 @@ import pwc.taxtech.atms.entity.TemplateGroup;
import pwc.taxtech.atms.entity.TemplateGroupExample; import pwc.taxtech.atms.entity.TemplateGroupExample;
import pwc.taxtech.atms.exception.ServiceException; import pwc.taxtech.atms.exception.ServiceException;
import pwc.taxtech.atms.vat.dao.PeriodDataSourceMapper; import pwc.taxtech.atms.vat.dao.PeriodDataSourceMapper;
import pwc.taxtech.atms.vat.entity.FileUpload;
import pwc.taxtech.atms.vat.entity.PeriodDataSource; import pwc.taxtech.atms.vat.entity.PeriodDataSource;
import java.io.ByteArrayOutputStream; import java.io.ByteArrayOutputStream;
...@@ -68,7 +70,8 @@ public class TemplateGroupServiceImpl extends AbstractService { ...@@ -68,7 +70,8 @@ public class TemplateGroupServiceImpl extends AbstractService {
private CellTemplateConfigDao cellTemplateConfigDao; private CellTemplateConfigDao cellTemplateConfigDao;
@Autowired @Autowired
private PeriodDataSourceMapper periodDataSourceMapper; private PeriodDataSourceMapper periodDataSourceMapper;
@Autowired
private DidiFileUploadService didiFileUploadService;
public List<TemplateGroupDto> get() { public List<TemplateGroupDto> get() {
List<TemplateGroup> templateGroups = templateGroupMapper.selectByExample(new TemplateGroupExample()); List<TemplateGroup> templateGroups = templateGroupMapper.selectByExample(new TemplateGroupExample());
List<TemplateGroupDto> templateGroupDtos = new ArrayList<>(); List<TemplateGroupDto> templateGroupDtos = new ArrayList<>();
...@@ -221,19 +224,21 @@ public class TemplateGroupServiceImpl extends AbstractService { ...@@ -221,19 +224,21 @@ public class TemplateGroupServiceImpl extends AbstractService {
} }
ByteArrayOutputStream bos = new ByteArrayOutputStream(); ByteArrayOutputStream bos = new ByteArrayOutputStream();
optional.get().write(bos); optional.get().write(bos);
String tmpPath = httpFileService.uploadTemplate(newName, file); //上传didi服务器文件
FileUpload fileUpload = didiFileUploadService.uploadFile(file,file.getOriginalFilename(), FileUploadEnum.BizSource.REPORT_TEMPLATE_UPLOAD.name());
// String tmpPath = httpFileService.uploadTemplate(newName, file);
String[] arr = sheetName.split("_"); String[] arr = sheetName.split("_");
String name = arr.length >= 2 ? arr[1] : arr[0]; String name = arr.length >= 2 ? arr[1] : arr[0];
Template template = new Template(); Template template = new Template();
template.setCode(arr[0]); template.setCode(arr[0]);
template.setReportType(templateGroupDto.getReportType());
template.setCreateTime(now); template.setCreateTime(now);
template.setId(distributedIdService.nextId()); template.setId(distributedIdService.nextId());
template.setIsActiveAssociation(true); template.setIsActiveAssociation(true);
template.setIsSystemType(false); template.setIsSystemType(false);
template.setName(name); template.setName(name);
template.setOrderIndex(i + 1); template.setOrderIndex(i + 1);
template.setPath(tmpPath); template.setPath(fileUpload.getUid());
// template.setReportType(tmpPath);
template.setTemplateGroupId(templateGroupId); template.setTemplateGroupId(templateGroupId);
filePathList.add(template); filePathList.add(template);
templateMapper.insertSelective(template); templateMapper.insertSelective(template);
......
package pwc.taxtech.atms.service.impl; package pwc.taxtech.atms.service.impl;
import com.github.pagehelper.PageInfo;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
import com.grapecity.documents.excel.C;
import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.CollectionUtils;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
...@@ -13,12 +13,12 @@ import pwc.taxtech.atms.constant.enums.TemplateGroupType; ...@@ -13,12 +13,12 @@ import pwc.taxtech.atms.constant.enums.TemplateGroupType;
import pwc.taxtech.atms.dpo.TemplateAndGroupDbDto; import pwc.taxtech.atms.dpo.TemplateAndGroupDbDto;
import pwc.taxtech.atms.dpo.TemplateUniqDto; import pwc.taxtech.atms.dpo.TemplateUniqDto;
import pwc.taxtech.atms.dto.*; import pwc.taxtech.atms.dto.*;
import pwc.taxtech.atms.dto.didiFileUpload.DidiFileIUploadParam;
import pwc.taxtech.atms.dto.didiFileUpload.DidiFileUploadDetailResult;
import pwc.taxtech.atms.dto.vatdto.TemplateByGroupDto; import pwc.taxtech.atms.dto.vatdto.TemplateByGroupDto;
import pwc.taxtech.atms.entity.*; import pwc.taxtech.atms.entity.*;
import pwc.taxtech.atms.vat.dao.PeriodReportMapper; import pwc.taxtech.atms.vat.dao.PeriodReportMapper;
import pwc.taxtech.atms.vat.dao.PeriodTemplateMapper;
import pwc.taxtech.atms.vat.entity.PeriodReportExample; import pwc.taxtech.atms.vat.entity.PeriodReportExample;
import pwc.taxtech.atms.vat.entity.PeriodTemplateExample;
import java.util.*; import java.util.*;
import java.util.stream.Collectors; import java.util.stream.Collectors;
...@@ -31,6 +31,8 @@ public class TemplateServiceImpl extends AbstractService { ...@@ -31,6 +31,8 @@ public class TemplateServiceImpl extends AbstractService {
@Autowired @Autowired
private PeriodReportMapper periodReportMapper; private PeriodReportMapper periodReportMapper;
@Autowired
private DidiFileUploadService didiFileUploadService;
public void addExistTemplate(TemplateAddExistDto templateAddExistDto){ public void addExistTemplate(TemplateAddExistDto templateAddExistDto){
TemplateExample t = new TemplateExample(); TemplateExample t = new TemplateExample();
t.createCriteria().andTemplateGroupIdEqualTo(templateAddExistDto.getTemplateGroupId()); t.createCriteria().andTemplateGroupIdEqualTo(templateAddExistDto.getTemplateGroupId());
...@@ -91,10 +93,20 @@ public class TemplateServiceImpl extends AbstractService { ...@@ -91,10 +93,20 @@ public class TemplateServiceImpl extends AbstractService {
List<Template> templates = templateMapper.selectByExample(example); List<Template> templates = templateMapper.selectByExample(example);
List<TemplateDto> templateDtos = new ArrayList<>(); List<TemplateDto> templateDtos = new ArrayList<>();
//从文件上传表转换path
DidiFileIUploadParam fileParam = new DidiFileIUploadParam();
fileParam.setUuids(templates.stream()
.map(o -> o.getPath()).collect(Collectors.toList()));
PageInfo<DidiFileUploadDetailResult> uploadDetail = didiFileUploadService.queryPage(fileParam);
Map<String,String> urlMap = null;
if(CollectionUtils.isNotEmpty(uploadDetail.getList())){
urlMap = uploadDetail.getList().stream().collect(Collectors.toMap(DidiFileUploadDetailResult::getUid, didiFileUploadDetailResult -> didiFileUploadDetailResult.getViewHttpUrl()));
}
for (Template template : templates) { for (Template template : templates) {
TemplateDto dto = new TemplateDto(); TemplateDto dto = new TemplateDto();
CommonUtils.copyProperties(template, dto); CommonUtils.copyProperties(template, dto);
dto.setId(template.getId().toString()); dto.setId(template.getId().toString());
dto.setPath(urlMap.get(template.getPath()));
templateDtos.add(dto); templateDtos.add(dto);
} }
return templateDtos; return templateDtos;
...@@ -111,6 +123,15 @@ public class TemplateServiceImpl extends AbstractService { ...@@ -111,6 +123,15 @@ public class TemplateServiceImpl extends AbstractService {
} else { } else {
result = template.getPath(); result = template.getPath();
} }
if(result.indexOf("/")<=0){
DidiFileIUploadParam fileParam = new DidiFileIUploadParam();
fileParam.setUuids(Arrays.asList(result));
PageInfo<DidiFileUploadDetailResult> uploadDetail = didiFileUploadService.queryPage(fileParam);
Map<String,String> urlMap = null;
if(CollectionUtils.isNotEmpty(uploadDetail.getList())){
result = uploadDetail.getList().get(0).getViewHttpUrl();
}
}
} }
return result; return result;
} }
......
package pwc.taxtech.atms.vat.service.impl; package pwc.taxtech.atms.vat.service.impl;
import com.github.pagehelper.PageInfo;
import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException; import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.ss.formula.functions.FreeRefFunction; import org.apache.poi.ss.formula.functions.FreeRefFunction;
...@@ -17,10 +19,14 @@ import org.springframework.stereotype.Component; ...@@ -17,10 +19,14 @@ import org.springframework.stereotype.Component;
import pwc.taxtech.atms.common.POIUtil; import pwc.taxtech.atms.common.POIUtil;
import pwc.taxtech.atms.common.util.SpringContextUtil; import pwc.taxtech.atms.common.util.SpringContextUtil;
import pwc.taxtech.atms.constant.enums.CellDataSourceType; import pwc.taxtech.atms.constant.enums.CellDataSourceType;
import pwc.taxtech.atms.constant.enums.FileUploadEnum;
import pwc.taxtech.atms.dao.ProjectMapper; import pwc.taxtech.atms.dao.ProjectMapper;
import pwc.taxtech.atms.dto.didiFileUpload.DidiFileIUploadParam;
import pwc.taxtech.atms.dto.didiFileUpload.DidiFileUploadDetailResult;
import pwc.taxtech.atms.dto.vatdto.CellCalcInfoDto; import pwc.taxtech.atms.dto.vatdto.CellCalcInfoDto;
import pwc.taxtech.atms.dto.vatdto.PeriodResources; import pwc.taxtech.atms.dto.vatdto.PeriodResources;
import pwc.taxtech.atms.exception.Exceptions; import pwc.taxtech.atms.exception.Exceptions;
import pwc.taxtech.atms.service.impl.DidiFileUploadService;
import pwc.taxtech.atms.service.impl.DistributedIdService; import pwc.taxtech.atms.service.impl.DistributedIdService;
import pwc.taxtech.atms.service.impl.HttpFileService; import pwc.taxtech.atms.service.impl.HttpFileService;
import pwc.taxtech.atms.vat.dao.*; import pwc.taxtech.atms.vat.dao.*;
...@@ -28,9 +34,7 @@ import pwc.taxtech.atms.vat.dpo.PeriodCellTemplateConfigExtendDto; ...@@ -28,9 +34,7 @@ import pwc.taxtech.atms.vat.dpo.PeriodCellTemplateConfigExtendDto;
import pwc.taxtech.atms.vat.entity.*; import pwc.taxtech.atms.vat.entity.*;
import pwc.taxtech.atms.vat.service.impl.report.functions.*; import pwc.taxtech.atms.vat.service.impl.report.functions.*;
import java.io.File; import java.io.*;
import java.io.IOException;
import java.io.InputStream;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.util.*; import java.util.*;
import java.util.regex.Matcher; import java.util.regex.Matcher;
...@@ -65,7 +69,8 @@ public class ReportGeneratorImpl { ...@@ -65,7 +69,8 @@ public class ReportGeneratorImpl {
private DistributedIdService distributedIdService; private DistributedIdService distributedIdService;
@Autowired @Autowired
private PeriodJobMapper periodJobMapper; private PeriodJobMapper periodJobMapper;
@Autowired
private DidiFileUploadService didiFileUploadService;
public FormulaContext initContext(PeriodResources resources, Integer period) { public FormulaContext initContext(PeriodResources resources, Integer period) {
return FormulaContext.extractContextFromProject(resources.getProject()).fixedFormula(period, resources.getTemplateGroupId(), return FormulaContext.extractContextFromProject(resources.getProject()).fixedFormula(period, resources.getTemplateGroupId(),
...@@ -466,6 +471,7 @@ public class ReportGeneratorImpl { ...@@ -466,6 +471,7 @@ public class ReportGeneratorImpl {
Workbook tWorkbook = null; Workbook tWorkbook = null;
File file = null; File file = null;
if (a.getIsSystemType()) { if (a.getIsSystemType()) {
file = new File(tempPath + a.getPath()); file = new File(tempPath + a.getPath());
try { try {
tWorkbook = WorkbookFactory.create(file); tWorkbook = WorkbookFactory.create(file);
...@@ -477,7 +483,19 @@ public class ReportGeneratorImpl { ...@@ -477,7 +483,19 @@ public class ReportGeneratorImpl {
} else { } else {
InputStream is = null; InputStream is = null;
try { try {
is = httpFileService.getUserTemplate(a.getPath()); String path = "";
if (a.getPath().indexOf("/") > 0) {
path = a.getPath();
} else {
DidiFileIUploadParam fileParam = new DidiFileIUploadParam();
fileParam.setUuids(Arrays.asList(a.getPath()));
PageInfo<DidiFileUploadDetailResult> uploadDetail = didiFileUploadService.queryPage(fileParam);
Map<String, String> urlMap = null;
if (CollectionUtils.isNotEmpty(uploadDetail.getList())) {
path = uploadDetail.getList().get(0).getViewHttpUrl();
}
}
is = httpFileService.getUserTemplate(path);
tWorkbook = WorkbookFactory.create(is); tWorkbook = WorkbookFactory.create(is);
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
...@@ -491,7 +509,28 @@ public class ReportGeneratorImpl { ...@@ -491,7 +509,28 @@ public class ReportGeneratorImpl {
} }
} }
} }
//TODO 当是税金计算表时动态添加行
if ("VAT8002".equals(a.getCode())) {
tWorkbook = assembleTaxWorkBook(tWorkbook);
//覆盖template地址
ByteArrayOutputStream bout = new ByteArrayOutputStream();
try {
tWorkbook.write(bout);
FileUpload fileUpload = didiFileUploadService.uploadFile(bout.toByteArray(), a.getCode() + "_" + a.getName() + ".xlsx", FileUploadEnum.BizSource.PERIOD_REPORT_TEMPLATE_UPLOAD.name());
a.setPath(fileUpload.getUid());
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
bout.close();
} catch (Exception e) {
}
}
periodTemplateMapper.updateByPrimaryKey(a);
}
POIUtil.cloneSheet(tWorkbook.getSheetAt(0), workbook.createSheet(a.getCode())); POIUtil.cloneSheet(tWorkbook.getSheetAt(0), workbook.createSheet(a.getCode()));
}); });
return workbook; return workbook;
} catch (Exception e) { } catch (Exception e) {
...@@ -503,6 +542,30 @@ public class ReportGeneratorImpl { ...@@ -503,6 +542,30 @@ public class ReportGeneratorImpl {
} }
} }
public Workbook assembleTaxWorkBook(Workbook tWorkbook) {
Sheet sheet = tWorkbook.getSheetAt(0);
Row row = POIUtil.createRow(sheet, 3);
Cell cell = row.createCell(0);
cell.setCellValue("test");
return tWorkbook;
}
private void saveExcel(Workbook wb) {
FileOutputStream fileOut;
try {
fileOut = new FileOutputStream("");
wb.write(fileOut);
fileOut.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
/** /**
* 注册所有的自定义方法到工作簿 * 注册所有的自定义方法到工作簿
* *
......
...@@ -60,8 +60,6 @@ ...@@ -60,8 +60,6 @@
"TaxData": "税务数据", "TaxData": "税务数据",
"AccountTotalepreciationAmount": "累计折旧额", "AccountTotalepreciationAmount": "累计折旧额",
"SetAssetGroup": "资产分类", "SetAssetGroup": "资产分类",
"AssetStatus": "状态",
"AssetStatus": "状态",
"LevelOneGroup": "一级分类", "LevelOneGroup": "一级分类",
"LevelTwoGroup": "二级分类", "LevelTwoGroup": "二级分类",
"LevelOneGroupValidation": "请选择一级分类", "LevelOneGroupValidation": "请选择一级分类",
...@@ -386,7 +384,6 @@ ...@@ -386,7 +384,6 @@
"CoverImportOutputInvoice": "覆盖导入销项发票", "CoverImportOutputInvoice": "覆盖导入销项发票",
"CoverImportTrialBalance": "覆盖导入试算平衡表", "CoverImportTrialBalance": "覆盖导入试算平衡表",
"CreateTask": "新建税务事项", "CreateTask": "新建税务事项",
"CreditAmount": "贷方发生",
"CreditAmountConfirmCol": "最终确认数(贷方)", "CreditAmountConfirmCol": "最终确认数(贷方)",
"CreditBal": "贷方发生额", "CreditBal": "贷方发生额",
"CreditBalDiff": "贷方差额", "CreditBalDiff": "贷方差额",
...@@ -455,7 +452,6 @@ ...@@ -455,7 +452,6 @@
"DataSourceNotFound": "数据源不存在", "DataSourceNotFound": "数据源不存在",
"DataValidation": "数据验证", "DataValidation": "数据验证",
"DateWarningSearch": "前日期不能大于后日期", "DateWarningSearch": "前日期不能大于后日期",
"DebitAmount": "借方发生",
"DebitAmountConfirmCol": "最终确认数(借方)", "DebitAmountConfirmCol": "最终确认数(借方)",
"DebitBal": "借方发生额", "DebitBal": "借方发生额",
"DebitBalDiff": "借方差额", "DebitBalDiff": "借方差额",
...@@ -838,7 +834,6 @@ ...@@ -838,7 +834,6 @@
"PleaseSelectAtLeastOneItem": "请选择至少一项!", "PleaseSelectAtLeastOneItem": "请选择至少一项!",
"PleaseSelectColumn": "请选择列名", "PleaseSelectColumn": "请选择列名",
"PleaseSelectFileFirst": "请先选择文件!", "PleaseSelectFileFirst": "请先选择文件!",
"PleaseSelectPeriod": "请选择一个期间",
"PleaseSelectTB": "请选择更新标准科目余额表", "PleaseSelectTB": "请选择更新标准科目余额表",
"ProductName": "商品名称", "ProductName": "商品名称",
"ProductStandar": "规格", "ProductStandar": "规格",
...@@ -1117,13 +1112,10 @@ ...@@ -1117,13 +1112,10 @@
"bsGenerateVer": "试算平衡生成版", "bsGenerateVer": "试算平衡生成版",
"bsMappingVer": "试算平衡Mapping版", "bsMappingVer": "试算平衡Mapping版",
"salaryAdvance": "预提重分类", "salaryAdvance": "预提重分类",
"eamDisposal": "EAM资产处置金额记录表",
"createTime": "创建时间",
"importWay": "导入方式", "importWay": "导入方式",
"TrialBalanceGeneVer": "试算平衡表生成版", "TrialBalanceGeneVer": "试算平衡表生成版",
"TrialBalanceMappingVer": "试算平衡表Mapping版", "TrialBalanceMappingVer": "试算平衡表Mapping版",
"AccountDescription": "科目说明", "AccountDescription": "科目说明",
"AccountPeriod": "期间",
"DebitAmount": "借方发生额", "DebitAmount": "借方发生额",
"CreditAmount": "贷方发生额", "CreditAmount": "贷方发生额",
"BeginningBalance": "期初余额", "BeginningBalance": "期初余额",
...@@ -1138,7 +1130,6 @@ ...@@ -1138,7 +1130,6 @@
"createBy": "创建人", "createBy": "创建人",
"createTime" : "创建时间", "createTime" : "创建时间",
"citSalaryAdvance" : "预提重分类数据源", "citSalaryAdvance" : "预提重分类数据源",
"assetLabelNumber" : "资产标签号",
"compensationSaleAmount" : "赔偿/变卖金额", "compensationSaleAmount" : "赔偿/变卖金额",
"EAMDisposal" : "EAM资产处理金额", "EAMDisposal" : "EAM资产处理金额",
"MainBodyCode": "主体代码", "MainBodyCode": "主体代码",
...@@ -1179,7 +1170,6 @@ ...@@ -1179,7 +1170,6 @@
"scrapReason" : "报废原因", "scrapReason" : "报废原因",
"assetNumber" : "资产编号", "assetNumber" : "资产编号",
"assetLabelNumber" : "资产标签号", "assetLabelNumber" : "资产标签号",
"compensationSaleAmount" : "赔偿/变卖金额",
"liableEmployeeNum" : "员工工号", "liableEmployeeNum" : "员工工号",
"liableEmployeeName" : "员工姓名", "liableEmployeeName" : "员工姓名",
"remitEmployeeNum" : "员工工号", "remitEmployeeNum" : "员工工号",
......
...@@ -1825,6 +1825,7 @@ ng-show="hasEditPermission && ToggleSaveAs && editModel.hasModel"/>'); ...@@ -1825,6 +1825,7 @@ ng-show="hasEditPermission && ToggleSaveAs && editModel.hasModel"/>');
$scope.$apply(function () { $scope.$apply(function () {
$scope.templateGroupModel = {}; $scope.templateGroupModel = {};
$scope.templateGroupModel.reportTypeList = $scope.detailReportTypeList
$scope.templateGroupModel.serviceTypeID = $scope.curServiceTypeId; $scope.templateGroupModel.serviceTypeID = $scope.curServiceTypeId;
$scope.templateGroupModel.industryIDs = $scope.curIndustry.id; $scope.templateGroupModel.industryIDs = $scope.curIndustry.id;
......
...@@ -453,13 +453,22 @@ controller('editTemplategroupModalController', ['$scope', '$log', '$translate', ...@@ -453,13 +453,22 @@ controller('editTemplategroupModalController', ['$scope', '$log', '$translate',
newModel: function() { newModel: function() {
var editModel = $scope.objectModel; var editModel = $scope.objectModel;
$scope.editModel = editModel; $scope.editModel = editModel;
$scope.editModel.name = ''; $scope.editModel.name = '';
$scope.editModel.sheetSelectDxID = thisConstant.sheetSelectDxID; $scope.editModel.sheetSelectDxID = thisConstant.sheetSelectDxID;
$scope.editModel.file = null; $scope.editModel.file = null;
$scope.editModel.nameError = null; $scope.editModel.nameError = null;
$scope.searchOptions = {
reportTypeOptions: {
displayExpr: 'name',
valueExpr: 'value',
bindingOptions: {
value: 'editModel.reportType'
},
dataSource: $scope.objectModel.reportTypeList.dataSource._array
}
};
$scope.editModel.reportTypeList = null;
var modalInstance = $uibModal.open({ var modalInstance = $uibModal.open({
animation: false, animation: false,
ariaLabelledBy: 'modal-title', ariaLabelledBy: 'modal-title',
......
...@@ -28,6 +28,15 @@ ...@@ -28,6 +28,15 @@
<div id={{::editModel.sheetSelectDxID}}></div> <div id={{::editModel.sheetSelectDxID}}></div>
</div> </div>
</div> </div>
<div class="form-group">
<label for="telCode" class="col-sm-5 control-label"><span class="must-input">*</span>报表类型:</label>
<div class="col-sm-5">
<div class="tab-content-select reportType col-md-2"
dx-select-box="searchOptions.reportTypeOptions">
</div>
</div>
</div>
<div class="form-group radio-wrapper"> <div class="form-group radio-wrapper">
<label for="telCode" class="col-sm-4 normal-label"> <label for="telCode" class="col-sm-4 normal-label">
<input type="radio" id="allowManual"><span>允许手工录入</span></label> <input type="radio" id="allowManual"><span>允许手工录入</span></label>
......
...@@ -45,3 +45,27 @@ ...@@ -45,3 +45,27 @@
} }
} }
} }
.form-group {
.tab-content-select {
margin-right: 10px;
outline: none;
display: inline-block;
&.industry {
width: 100px;
}
&.reportType {
width: 120px;
}
&.selectTemplateGroup {
width: 150px;
}
&.selectReport {
width: 150px;
}
}
}
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment