Commit 3d9a5639 authored by eddie.woo's avatar eddie.woo

Merge branch 'dev_mysql' of http://code.tech.tax.asia.pwcinternal.com/root/atms into dev_mysql

parents 0e9d8280 67c59911
...@@ -52,7 +52,8 @@ public enum OperationModule { ...@@ -52,7 +52,8 @@ public enum OperationModule {
OrganizationTaxRule(40), OrganizationTaxRule(40),
Equity(41), Equity(41),
OrganizationEmployee(42), OrganizationEmployee(42),
OrganizationTaxpayerQualification(43); OrganizationTaxpayerQualification(43),
InitEquity(44);
private int value; private int value;
......
...@@ -20,6 +20,7 @@ public class LogMessage { ...@@ -20,6 +20,7 @@ public class LogMessage {
public static final String UpdateOrganizationEquity = "UpdateOrganizationEquity"; public static final String UpdateOrganizationEquity = "UpdateOrganizationEquity";
public static final String DeleteOrganizationEquity = "DeleteOrganizationEquity"; public static final String DeleteOrganizationEquity = "DeleteOrganizationEquity";
public static final String InitOrganizationEquity = "InitOrganizationEquity";
public static final String ChangeOrganizationEquity = "ChangeOrganizationEquity"; public static final String ChangeOrganizationEquity = "ChangeOrganizationEquity";
public static final String CancelChangeUpdateOrganizationEquity = "CancelChangeUpdateOrganizationEquity"; public static final String CancelChangeUpdateOrganizationEquity = "CancelChangeUpdateOrganizationEquity";
......
...@@ -10,7 +10,9 @@ public enum EnumImportType { ...@@ -10,7 +10,9 @@ public enum EnumImportType {
CoupaPurchasingReport(6), CoupaPurchasingReport(6),
InvoiceData(7), InvoiceData(7),
CertifiedInvoicesList(8), CertifiedInvoicesList(8),
InvoiceRecord(9) InvoiceRecord(9),
ExtractFinancialData(10),
ExtractInvoiceData(11)
; ;
private Integer code; private Integer code;
......
package pwc.taxtech.atms.constant.enums;
import java.util.HashMap;
import java.util.Map;
/**
* @Auther: Gary J Li
* @Date: 26/02/2019 13:50
* @Description:
*/
public enum NationalEconomicIndustryEnum {
A("农、林、牧、渔业"),
B("采矿业"),
C("制造业"),
D("电力、热力、燃气及水生产和供应业"),
E("建筑业"),
F("批发和零售业"),
G("交通运输、仓储和邮政业"),
H("住宿和餐饮业"),
I("信息传输、软件和信息技术服务业"),
J("金融业"),
K("房地产业"),
L("租赁和商务服务业"),
M("科学研究和技术服务业"),
N("水利、环境和公共设施管理业"),
O("居民服务、修理和其他服务业"),
P("教育"),
Q("卫生和社会工作"),
R("文化、体育和娱乐业"),
S("公共管理、社会保障和社会组织"),
T("国际组织") ;
private String name;
public static final Map<String, String> Map = new HashMap<>();
static {
for (NationalEconomicIndustryEnum kv : NationalEconomicIndustryEnum.values()) {
Map.put(kv.getName(), kv.name());
}
}
NationalEconomicIndustryEnum(String name) {
this.name = name;
}
public String getName() {
return name;
}
}
...@@ -6,10 +6,9 @@ import com.google.common.collect.Lists; ...@@ -6,10 +6,9 @@ import com.google.common.collect.Lists;
import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartFile;
import pwc.taxtech.atms.common.message.ErrorMessage; import pwc.taxtech.atms.common.message.ErrorMessage;
import pwc.taxtech.atms.dpo.PagingDto; import pwc.taxtech.atms.dpo.PagingDto;
import pwc.taxtech.atms.dto.ApiResultDto; import pwc.taxtech.atms.dto.*;
import pwc.taxtech.atms.dto.DataImportLogDto; import pwc.taxtech.atms.dto.dataimport.DataImportParam;
import pwc.taxtech.atms.dto.OperationResultDto; import pwc.taxtech.atms.dto.input.CamelPagingResultDto;
import pwc.taxtech.atms.dto.PagingResultDto;
import pwc.taxtech.atms.dto.vatdto.TrialBalanceDto; import pwc.taxtech.atms.dto.vatdto.TrialBalanceDto;
import pwc.taxtech.atms.dto.vatdto.TrialBalanceParam; import pwc.taxtech.atms.dto.vatdto.TrialBalanceParam;
import pwc.taxtech.atms.exception.ServiceException; import pwc.taxtech.atms.exception.ServiceException;
...@@ -198,14 +197,34 @@ public class DataImportController extends BaseController { ...@@ -198,14 +197,34 @@ public class DataImportController extends BaseController {
} }
@ResponseBody @ResponseBody
@RequestMapping(value = "displayImportLog", method = RequestMethod.GET) @RequestMapping(value = "displayImportLog", method = RequestMethod.POST)
public List<DataImportLogDto> displayImportLog(@RequestParam Integer type) { public CamelPagingResultDto<DataImportLogDto> displayImportLog(@RequestBody DataImportParam param) {
List<DataImportLogDto> dataImportLogDtos = Lists.newArrayList(); return new CamelPagingResultDto<>(dataImportService.displayImportLog(param));
}
@ResponseBody
@RequestMapping(value = "callExtractFinancialData", method = RequestMethod.POST)
public OperationResultDto callExtractFinancialData(@RequestBody DataExtractParam dataExtractParam) {
try { try {
dataImportLogDtos = dataImportService.displayImportLog(type); return dataImportService.callExtractFinancialData(dataExtractParam);
} catch (ServiceException e) {
return OperationResultDto.error(e.getMessage());
} catch (Exception e) { } catch (Exception e) {
logger.error("displayImportLog error.", e); logger.error("callExtractFinancialData error.", e);
return OperationResultDto.error(ErrorMessage.SystemError);
}
}
@ResponseBody
@RequestMapping(value = "callExtractInvoiceData", method = RequestMethod.POST)
public OperationResultDto callExtractInvoiceData(@RequestBody DataExtractParam dataExtractParam) {
try {
return dataImportService.callExtractInvoiceData(dataExtractParam);
} catch (ServiceException e) {
return OperationResultDto.error(e.getMessage());
} catch (Exception e) {
logger.error("callExtractInvoiceData error.", e);
return OperationResultDto.error(ErrorMessage.SystemError);
} }
return dataImportLogDtos;
} }
} }
...@@ -6,10 +6,7 @@ import org.slf4j.LoggerFactory; ...@@ -6,10 +6,7 @@ import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.MediaType; import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import pwc.taxtech.atms.dpo.OrgBasicDto; import pwc.taxtech.atms.dpo.*;
import pwc.taxtech.atms.dpo.OrgInfoDto;
import pwc.taxtech.atms.dpo.OrgSimpleDto;
import pwc.taxtech.atms.dpo.OrganizationDto;
import pwc.taxtech.atms.dto.*; import pwc.taxtech.atms.dto.*;
import pwc.taxtech.atms.dto.organization.OrganizationExtraDto; import pwc.taxtech.atms.dto.organization.OrganizationExtraDto;
import pwc.taxtech.atms.dto.dimension.DimensionOrgDtoDashboard; import pwc.taxtech.atms.dto.dimension.DimensionOrgDtoDashboard;
...@@ -93,9 +90,10 @@ public class OrganizationController { ...@@ -93,9 +90,10 @@ public class OrganizationController {
return organizationService.getOrgInfo(); return organizationService.getOrgInfo();
} }
// 这是这个重复的方法
@RequestMapping(value = "getOrgListByUserId", method = RequestMethod.GET) @RequestMapping(value = "getOrgListByUserId", method = RequestMethod.GET)
public @ResponseBody public @ResponseBody
List<OrgSimpleDto> getOrgSimpleList() { List<OrgSelectDto> getOrgSimpleList() {
logger.info("GET /api/v1/org/getOrgListByUserId"); logger.info("GET /api/v1/org/getOrgListByUserId");
return organizationService.getOrgSimpleList(); return organizationService.getOrgSimpleList();
} }
......
package pwc.taxtech.atms.dto;
import java.util.List;
public class DataExtractParam {
private String period;
private List<String> orgIds;
private List<Integer> dataTypes;
public String getPeriod() {
return period;
}
public void setPeriod(String period) {
this.period = period;
}
public List<String> getOrgIds() {
return orgIds;
}
public void setOrgIds(List<String> orgIds) {
this.orgIds = orgIds;
}
public List<Integer> getDataTypes() {
return dataTypes;
}
public void setDataTypes(List<Integer> dataTypes) {
this.dataTypes = dataTypes;
}
}
package pwc.taxtech.atms.dto.dataimport;
import pwc.taxtech.atms.dto.input.CamelPagingDto;
import pwc.taxtech.atms.vat.entity.RevenueConfig;
public class DataImportParam {
private CamelPagingDto pageInfo;
private Integer type;
public CamelPagingDto getPageInfo() {
return this.pageInfo;
}
public void setPageInfo(CamelPagingDto pageInfo) {
this.pageInfo = pageInfo;
}
public Integer getType() {
return type;
}
public void setType(Integer type) {
this.type = type;
}
}
package pwc.taxtech.atms.service.impl; package pwc.taxtech.atms.service.impl;
import java.util.Date; import java.util.Date;
import com.github.pagehelper.Page;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang3.ObjectUtils; import org.apache.commons.lang3.ObjectUtils;
...@@ -17,8 +20,11 @@ import pwc.taxtech.atms.constant.Constant; ...@@ -17,8 +20,11 @@ import pwc.taxtech.atms.constant.Constant;
import pwc.taxtech.atms.constant.enums.EnumImportType; import pwc.taxtech.atms.constant.enums.EnumImportType;
import pwc.taxtech.atms.constant.enums.EnumTbImportType; import pwc.taxtech.atms.constant.enums.EnumTbImportType;
import pwc.taxtech.atms.dao.*; import pwc.taxtech.atms.dao.*;
import pwc.taxtech.atms.dpo.OrgSelectDto;
import pwc.taxtech.atms.dto.DataExtractParam;
import pwc.taxtech.atms.dto.DataImportLogDto; import pwc.taxtech.atms.dto.DataImportLogDto;
import pwc.taxtech.atms.dto.OperationResultDto; import pwc.taxtech.atms.dto.OperationResultDto;
import pwc.taxtech.atms.dto.dataimport.DataImportParam;
import pwc.taxtech.atms.dto.vatdto.TrialBalanceDto; import pwc.taxtech.atms.dto.vatdto.TrialBalanceDto;
import pwc.taxtech.atms.dto.vatdto.TrialBalanceParam; import pwc.taxtech.atms.dto.vatdto.TrialBalanceParam;
import pwc.taxtech.atms.entity.*; import pwc.taxtech.atms.entity.*;
...@@ -78,6 +84,8 @@ public class DataImportService extends BaseService { ...@@ -78,6 +84,8 @@ public class DataImportService extends BaseService {
private CertifiedInvoicesListMapper certifiedInvoicesListMapper; private CertifiedInvoicesListMapper certifiedInvoicesListMapper;
@Resource @Resource
private InvoiceRecordMapper invoiceRecordMapper; private InvoiceRecordMapper invoiceRecordMapper;
@Autowired
private OrganizationServiceImpl organizationService;
/** /**
* TB表查询 * TB表查询
...@@ -1543,21 +1551,38 @@ public class DataImportService extends BaseService { ...@@ -1543,21 +1551,38 @@ public class DataImportService extends BaseService {
return res; return res;
} }
public List<DataImportLogDto> displayImportLog(Integer type) {
List<DataImportLogDto> dataImportLogDtos = Lists.newArrayList(); /**
DataImportLogExample dataImportLogExample = new DataImportLogExample(); * 25/02/2019 18:52
if(EnumImportType.Undefined.getCode().equals(type)){ *
dataImportLogExample.setOrderByClause("update_time desc"); * [type]
}else{ * @author Gary J Li
dataImportLogExample.createCriteria().andTypeEqualTo(type).andDisplayEqualTo(true); * @return
dataImportLogExample.setOrderByClause("update_time desc"); *
*/
public PageInfo<DataImportLogDto> displayImportLog(DataImportParam param) {
DataImportLogExample example = new DataImportLogExample();
DataImportLogExample.Criteria criteria =example.createCriteria();
Page page = PageHelper.startPage(param.getPageInfo().getPageIndex(), param.getPageInfo().getPageSize());
List<String> orgIds = organizationService.getMyOrgList().stream().map(OrgSelectDto::getId).collect(Collectors.toList());
// 这里会导致任何人都可以看到未映射到主体的数据
orgIds.add("");
if(!EnumImportType.Undefined.getCode().equals(param.getType())){
criteria.andTypeEqualTo(param.getType()).andDisplayEqualTo(true);
criteria.andOrganizationIdIn(orgIds);
} }
dataImportLogMapper.selectByExample(dataImportLogExample).forEach( dil ->{ example.setOrderByClause("update_time desc");
DataImportLogDto dataImportLogDto = new DataImportLogDto();
beanUtil.copyProperties(dil,dataImportLogDto); PageInfo<DataImportLogDto> pageInfo = new PageInfo<>(dataImportLogMapper.selectByExample(example).stream()
dataImportLogDtos.add(dataImportLogDto); .map(o -> beanUtil.copyProperties(o, new DataImportLogDto())).collect(Collectors.toList()));
}); pageInfo.setTotal(page.getTotal());
return dataImportLogDtos;
return pageInfo;
} }
private boolean isSheetEmpty(Sheet sheet) { private boolean isSheetEmpty(Sheet sheet) {
...@@ -1568,4 +1593,37 @@ public class DataImportService extends BaseService { ...@@ -1568,4 +1593,37 @@ public class DataImportService extends BaseService {
} }
return false; return false;
} }
public OperationResultDto callExtractFinancialData(DataExtractParam dataExtractParam) {
// todo 调用滴滴的http财务数据抽取调用接口 List<String> codes, Integer period, List<Integer> dataTypes
OrganizationExample example = new OrganizationExample();
example.createCriteria().andIdIn(dataExtractParam.getOrgIds());
List<String> codes = organizationMapper.selectByExample(example).stream().map(Organization::getCode).collect(Collectors.toList());
Integer tmsPeriod = DateUtils.strToPeriod(dataExtractParam.getPeriod());
// data_import_log 日志记录为 EnumImportType.ExtractFinancialData
return OperationResultDto.success();
}
/**
* 25/02/2019 18:26
*
* [orgIds, period, dataTypes]
* @author Gary J Li
* @return
* remark:1、这里重复写了,因为可能调用场景不同?
*/
public OperationResultDto callExtractInvoiceData(DataExtractParam dataExtractParam) {
// todo 调用滴滴的http发票数据抽取调用接口 List<String> codes, Integer period, List<Integer> dataTypes
OrganizationExample example = new OrganizationExample();
example.createCriteria().andIdIn(dataExtractParam.getOrgIds());
List<String> codes = organizationMapper.selectByExample(example).stream().map(Organization::getCode).collect(Collectors.toList());
Integer tmsPeriod = DateUtils.strToPeriod(dataExtractParam.getPeriod());
// data_import_log 日志记录为 EnumImportType.ExtractInvoiceData
return OperationResultDto.success();
}
} }
package pwc.taxtech.atms.service.impl; package pwc.taxtech.atms.service.impl;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.BeanUtils; import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import pwc.taxtech.atms.common.OperateLogType; import pwc.taxtech.atms.common.OperateLogType;
import pwc.taxtech.atms.common.OperationAction; import pwc.taxtech.atms.common.OperationAction;
import pwc.taxtech.atms.common.OperationModule; import pwc.taxtech.atms.common.OperationModule;
...@@ -217,7 +215,7 @@ public class EquityServiceImpl extends BaseService{ ...@@ -217,7 +215,7 @@ public class EquityServiceImpl extends BaseService{
} else { } else {
opLog.setAction(OperationAction.ChangeEquity.value()); opLog.setAction(OperationAction.ChangeEquity.value());
} }
opLog.setOperationContent(LogMessage.IsActive); opLog.setOperationContent(LogMessage.ChangeOrganizationEquity);
opLog.setOperationObject(orgName); opLog.setOperationObject(orgName);
opLog.setOriginalState(oldId == null ? "" : String.valueOf(oldId)); opLog.setOriginalState(oldId == null ? "" : String.valueOf(oldId));
opLog.setUpdateState(String.valueOf(newId)); opLog.setUpdateState(String.valueOf(newId));
......
...@@ -222,7 +222,7 @@ public class OrganizationServiceImpl extends BaseService{ ...@@ -222,7 +222,7 @@ public class OrganizationServiceImpl extends BaseService{
// find rootOrg // find rootOrg
List<Organization> rootOrgs = null; List<Organization> rootOrgs = null;
if (useType == 1) { if (useType == 1) {
rootOrgs = orgList.stream().filter(x -> x.getParentId() == null).collect(Collectors.toList()); rootOrgs = orgList.stream().filter(x -> StringUtils.isEmpty(x.getParentId())).collect(Collectors.toList());
} else { } else {
rootOrgs = orgList.stream() rootOrgs = orgList.stream()
.filter(x -> x.getParentId() == null && CommonConstants.ACTIVE_STATUS.equals(x.getIsActive())) .filter(x -> x.getParentId() == null && CommonConstants.ACTIVE_STATUS.equals(x.getIsActive()))
...@@ -242,7 +242,7 @@ public class OrganizationServiceImpl extends BaseService{ ...@@ -242,7 +242,7 @@ public class OrganizationServiceImpl extends BaseService{
private OrganizationDto genarateSubOrgs(OrganizationDto parentOrg, List<Organization> orgs, private OrganizationDto genarateSubOrgs(OrganizationDto parentOrg, List<Organization> orgs,
List<ServiceType> serviceList, Integer useType) { List<ServiceType> serviceList, Integer useType) {
if (parentOrg.getParentId() != null) { if (StringUtils.isNotEmpty(parentOrg.getParentId())) {
Organization organization = orgs.stream().filter(x -> x.getId().equals(parentOrg.getParentId())) Organization organization = orgs.stream().filter(x -> x.getId().equals(parentOrg.getParentId()))
.collect(Collectors.toList()).get(0); .collect(Collectors.toList()).get(0);
parentOrg.setParentName(organization == null ? null : organization.getName()); parentOrg.setParentName(organization == null ? null : organization.getName());
...@@ -1932,7 +1932,7 @@ public class OrganizationServiceImpl extends BaseService{ ...@@ -1932,7 +1932,7 @@ public class OrganizationServiceImpl extends BaseService{
} }
} }
result.setOrganizationServiceTemplateGroupList(query2); result.setOrganizationServiceTemplateGroupList(query2);
if (result.getParentId() == null) { if (StringUtils.isEmpty(result.getParentId())) {
result.setParentName(""); result.setParentName("");
} else { } else {
Organization tParent = organizationMapper.selectByExample(null).stream() Organization tParent = organizationMapper.selectByExample(null).stream()
...@@ -1948,7 +1948,9 @@ public class OrganizationServiceImpl extends BaseService{ ...@@ -1948,7 +1948,9 @@ public class OrganizationServiceImpl extends BaseService{
OrganizationExtraDto organizationExtraDto = new OrganizationExtraDto(); OrganizationExtraDto organizationExtraDto = new OrganizationExtraDto();
OrganizationExtra organizationExtra = organizationExtraMapper.selectByOrgId(orgId).stream().findFirst() OrganizationExtra organizationExtra = organizationExtraMapper.selectByOrgId(orgId).stream().findFirst()
.orElse(null); .orElse(null);
if(null!=organizationExtra){
beanUtil.copyProperties(organizationExtra,organizationExtraDto); beanUtil.copyProperties(organizationExtra,organizationExtraDto);
}
return organizationExtraDto; return organizationExtraDto;
} }
...@@ -2777,9 +2779,9 @@ public class OrganizationServiceImpl extends BaseService{ ...@@ -2777,9 +2779,9 @@ public class OrganizationServiceImpl extends BaseService{
* @author Gary J Li * @author Gary J Li
* @return * @return
*/ */
public List<OrgSimpleDto> getOrgSimpleList() { public List<OrgSelectDto> getOrgSimpleList() {
String userId = authUserHelper.getCurrentUserId(); String userId = authUserHelper.getCurrentUserId();
List<OrgSimpleDto> orgSimpleDtos = Lists.newArrayList(); List<OrgSelectDto> orgSelectDtos = Lists.newArrayList();
UserOrganizationExample userOrganizationExample = new UserOrganizationExample(); UserOrganizationExample userOrganizationExample = new UserOrganizationExample();
userOrganizationExample.createCriteria().andUserIdEqualTo(userId); userOrganizationExample.createCriteria().andUserIdEqualTo(userId);
List<UserOrganization> userOrganizations = userOrganizationMapper.selectByExample(userOrganizationExample); List<UserOrganization> userOrganizations = userOrganizationMapper.selectByExample(userOrganizationExample);
...@@ -2788,10 +2790,10 @@ public class OrganizationServiceImpl extends BaseService{ ...@@ -2788,10 +2790,10 @@ public class OrganizationServiceImpl extends BaseService{
organizationExample.createCriteria().andIdIn(orgIds); organizationExample.createCriteria().andIdIn(orgIds);
List<Organization> organizations = organizationMapper.selectByExample(organizationExample); List<Organization> organizations = organizationMapper.selectByExample(organizationExample);
organizations.forEach(o -> { organizations.forEach(o -> {
OrgSimpleDto orgSimpleDto = beanUtil.copyProperties(o,new OrgSimpleDto()); OrgSelectDto orgSelectDto = beanUtil.copyProperties(o,new OrgSelectDto());
orgSimpleDtos.add(orgSimpleDto); orgSelectDtos.add(orgSelectDto);
}); });
return orgSimpleDtos; return orgSelectDtos;
} }
/** /**
......
package pwc.taxtech.atms;
import java.util.HashMap;
import java.util.Map;
/**
* @Auther: Gary J Li
* @Date: 26/02/2019 13:50
* @Description:
*/
public enum OrgKV {
orgId("organizationId", "机构代码"),
registrationCapital("registrationCapital", "注册资本"),
paidInCapital("paidInCapital", "实缴资本"),
regStatus("regStatus", "经营状态"),
foundationDate("foundationDate", "成立日期"),
legalCode("legalCode", "统一社会信用代码"),
taxPayerNumber("taxPayerNumber", "纳税人识别号"),
// dontKnow("clientCode", "注册号"),
// dontKnow1("?", "组织机构代码"),
registrationType("registrationType", "公司类型"),
nationalEconomicIndustry("nationalEconomicIndustry", "所属行业"),//所属国民经济行业
// area("area", "所属地区"),
englishName("englishName", "英文名"),
employeesNumEnd("employeesNumEnd", "参保人数"),
registerAddress("registerAddress", "企业地址"),
businessScope("businessScope", "经营范围"),
eNum("eNum", "序号"),
investorName("investorName", "股东(发起人)"),
investmentRadio("investmentRadio", "持股比例"),//投资比例
investmentAmount("investmentAmount", "认缴出资额"),//投资金额
investmentAmount1("investmentAmount", "认缴出资额(万元)"),//投资金额
investmentAmount2("investmentAmount", "认缴出资额(万美元)"),//投资金额
// registrationCapital("registrationCapital", "认缴出资日期"),
payableCapitalContributionAmount("payableCapitalContributionAmount", "实缴出资额(万元)"),//实缴出资金额
// registrationCapital("registrationCapital", "实缴出资日期"),
createTime("createTime", "变更日期"),
comment("comment", "变更项目"),
originalState("originalState", "变更前"),
updateState("updateState", "变更后");
private String attribute;
private String name;
public static final Map<String, String> Map = new HashMap<>();
static {
for (OrgKV kv : OrgKV.values()) {
Map.put(kv.getName(), kv.getAttribute());
}
}
OrgKV(String attribute, String name) {
this.attribute = attribute;
this.name = name;
}
public String getAttribute() {
return attribute;
}
public String getName() {
return name;
}
}
package pwc.taxtech.atms.dto;
import java.util.List;
import java.util.Map;
/**
* @Auther: Gary J Li
* @Date: 26/02/2019 12:45
* @Description:
*/
public class OrgDto {
private List<Map> orgs;
public List<Map> getOrgs() {
return orgs;
}
public void setOrgs(List<Map> orgs) {
this.orgs = orgs;
}
}
package pwc.taxtech.atms.dao;
import java.util.List;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.session.RowBounds;
import pwc.taxtech.atms.MyMapper;
import pwc.taxtech.atms.entity.OperationLogEquity;
import pwc.taxtech.atms.entity.OperationLogEquityExample;
@Mapper
public interface OperationLogEquityMapper extends MyMapper {
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
long countByExample(OperationLogEquityExample example);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
int deleteByExample(OperationLogEquityExample example);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
int deleteByPrimaryKey(String id);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
int insert(OperationLogEquity record);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
int insertSelective(OperationLogEquity record);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
List<OperationLogEquity> selectByExampleWithRowbounds(OperationLogEquityExample example, RowBounds rowBounds);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
List<OperationLogEquity> selectByExample(OperationLogEquityExample example);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
OperationLogEquity selectByPrimaryKey(String id);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
int updateByExampleSelective(@Param("record") OperationLogEquity record, @Param("example") OperationLogEquityExample example);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
int updateByExample(@Param("record") OperationLogEquity record, @Param("example") OperationLogEquityExample example);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
int updateByPrimaryKeySelective(OperationLogEquity record);
/**
* This method was generated by MyBatis Generator.
* This method corresponds to the database table operation_log_equity
*
* @mbg.generated
*/
int updateByPrimaryKey(OperationLogEquity record);
}
\ No newline at end of file
...@@ -11,19 +11,19 @@ ...@@ -11,19 +11,19 @@
AND segment3= #{jeCondition.segment3,jdbcType=VARCHAR} AND segment3= #{jeCondition.segment3,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.segment3Name)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.segment3Name)">
AND segment3Name= #{jeCondition.segment3Name,jdbcType=VARCHAR} AND segment3_name= #{jeCondition.segment3Name,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.segment5)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.segment5)">
AND segment5= #{jeCondition.segment5,jdbcType=VARCHAR} AND segment5= #{jeCondition.segment5,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.segment5Name)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.segment5Name)">
AND segment5Name= #{jeCondition.segment5Name,jdbcType=VARCHAR} AND segment5_name= #{jeCondition.segment5Name,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.segment6)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.segment6)">
AND segment6= #{jeCondition.segment6,jdbcType=VARCHAR} AND segment6= #{jeCondition.segment6,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.segment6Name)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.segment6Name)">
AND segment6Name= #{jeCondition.segment6Name,jdbcType=VARCHAR} AND segment6_name= #{jeCondition.segment6Name,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.description)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(jeCondition.description)">
AND description= #{jeCondition.description,jdbcType=VARCHAR} AND description= #{jeCondition.description,jdbcType=VARCHAR}
......
...@@ -11,19 +11,19 @@ ...@@ -11,19 +11,19 @@
AND segment2= #{tbCondition.segment2,jdbcType=VARCHAR} AND segment2= #{tbCondition.segment2,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(tbCondition.segment2Name)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(tbCondition.segment2Name)">
AND segment2Name= #{tbCondition.segment2Name,jdbcType=VARCHAR} AND segment2_name= #{tbCondition.segment2Name,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(tbCondition.segment3)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(tbCondition.segment3)">
AND segment3= #{tbCondition.segment3,jdbcType=VARCHAR} AND segment3= #{tbCondition.segment3,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(tbCondition.segment3Name)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(tbCondition.segment3Name)">
AND segment3Name= #{tbCondition.segment3Name,jdbcType=VARCHAR} AND segment3_name= #{tbCondition.segment3Name,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(tbCondition.segment6)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(tbCondition.segment6)">
AND segment6= #{tbCondition.segment6,jdbcType=VARCHAR} AND segment6= #{tbCondition.segment6,jdbcType=VARCHAR}
</if> </if>
<if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(tbCondition.segment6Name)"> <if test="@com.github.pagehelper.util.StringUtil@isNotEmpty(tbCondition.segment6Name)">
AND segment6Name= #{tbCondition.segment6Name,jdbcType=VARCHAR} AND segment6_name= #{tbCondition.segment6Name,jdbcType=VARCHAR}
</if> </if>
<if test="tbCondition.periodStart!=null"> <if test="tbCondition.periodStart!=null">
AND period &gt;= #{tbCondition.periodStart,jdbcType=INTEGER} AND period &gt;= #{tbCondition.periodStart,jdbcType=INTEGER}
......
...@@ -306,6 +306,37 @@ ...@@ -306,6 +306,37 @@
"RecordSize": "Record Size", "RecordSize": "Record Size",
"TaxPayerIdNum": "纳税人识别号", "TaxPayerIdNum": "纳税人识别号",
"ExtractDistribution": "Extract Distribution",
"Log":"Log",
"DataImportRecord":"Data Import Record",
"DataProcessingCheckRecord":"Data Process Check Record",
"BillingRecordAndRevenueTypeMappingConfiguration":"BR-RT Mapping Config",
"InputRollOutConfiguration":"Input RollOut Config",
"FinancialDataExtraction":"Financial Data Extraction",
"InvoiceDataExtraction":"Invoice Data Extraction",
"ImportDistribution":"Import Distribution",
"VATInvoiceRecord":"VAT Invoice Record",
"CertifiedInvoicesList":"Certified Invoices List",
"RedLetterVATSpecialInvoiceInfo":"Red Letter Invoice Info",
"InvoiceInformation":"Invoice Information",
"CoupaInvoiceReport":"Coupa Invoice Report",
"AdjustmentTable":"Adjustment Table",
"BalanceSheetPRC":"BalanceSheet PRC",
"IncomeStatementPRC":"Income Statement PRC",
"CashFlowStatement":"Cash Flow Statement",
"OwnerEquityChangeStatement":"Owner Equity Change Statement",
"InvoiceStatistics":"Invoice Statistics",
"CITAdjustmentJournal":"CIT Adjustment Journal",
"CITTrialBalance":"CIT TrialBalance",
"CITDocumentSubjectMappingTable":"CIT Document Subject Mapping Table",
"CITBalanceSheetPRC":"CIT Balance Sheet PRC",
"CITProfitStatementPRC":"CIT Profit Statement PRC",
"CITEAMAssetDisposalAmountRecord":"CIT EAM Asset Disposal Amount Record",
"CITPreClassifiedDataSource":"CIT PreClassified DataSource",
"Configuration":"Configuration",
"RevenueTypeConfiguration":"Revenue Type Config",
"~MustBeEndOneApp": "I Must be the End One, please!" "~MustBeEndOneApp": "I Must be the End One, please!"
} }
\ No newline at end of file
...@@ -854,7 +854,35 @@ ...@@ -854,7 +854,35 @@
"RecordSize": "记录条数", "RecordSize": "记录条数",
"TaxPayerIdNum": "纳税人识别号", "TaxPayerIdNum": "纳税人识别号",
"ExtractDistribution": "抽取分发",
"Log":"日志",
"DataImportRecord":"数据导入记录",
"DataProcessingCheckRecord":"数据处理校验记录",
"BillingRecordAndRevenueTypeMappingConfiguration":"开票记录与收入类型映射配置",
"InputRollOutConfiguration":"进项转出配置",
"FinancialDataExtraction":"财务数据抽取",
"InvoiceDataExtraction":"发票数据抽取",
"ImportDistribution":"导入分发",
"VATInvoiceRecord":"已开增值税发票记录",
"CertifiedInvoicesList":"已认证发票清单",
"RedLetterVATSpecialInvoiceInfo":"红字增值税专用发票信息表",
"InvoiceInformation":"发票资料",
"CoupaInvoiceReport":"Coupa发票报告",
"AdjustmentTable":"调整表",
"BalanceSheetPRC":"资产负债表PRC",
"IncomeStatementPRC":"利润表PRC",
"CashFlowStatement":"现金流量表",
"OwnerEquityChangeStatement":"所有者权益变动表",
"InvoiceStatistics":"发票统计资料",
"CITAdjustmentJournal":"CIT-调整日记账",
"CITTrialBalance":"CIT-试算平衡表",
"CITDocumentSubjectMappingTable":"CIT-底稿&科目Mapping表",
"CITBalanceSheetPRC":"CIT-资产负债表(单家PRC)",
"CITProfitStatementPRC":"CIT-利润表(单家PRC)",
"CITEAMAssetDisposalAmountRecord":"CIT-EAM资产处置金额记录表",
"CITPreClassifiedDataSource":"CIT-预提重分类数据源",
"Configuration":"配置",
"RevenueTypeConfiguration":"收入类型配置",
"~MustBeEndOneApp": "I Must be the End One, please!" "~MustBeEndOneApp": "I Must be the End One, please!"
} }
\ No newline at end of file
...@@ -56,13 +56,14 @@ ...@@ -56,13 +56,14 @@
<div dx-data-grid="getDetailGridSettings(orgInfo)"></div> <div dx-data-grid="getDetailGridSettings(orgInfo)"></div>
</div> </div>
</div> </div>
<!--分页栏--> <!--分页栏 方便搜索机构,前台分页-->
</div> <!--<div class="form-group page-form-group">
<div class="form-group page-form-group">
<div class="page-footer"> <div class="page-footer">
<ack-pagination page-options="pagingOptions" refresh-table="pagingService.refreshOrgDataGrid()" hide-page-size-selector="true"></ack-pagination> <ack-pagination page-options="pagingOptions" refresh-table="pagingService.refreshOrgDataGrid()" hide-page-size-selector="true"></ack-pagination>
</div> </div>
</div>-->
</div> </div>
</div> </div>
</div> </div>
......
...@@ -2206,22 +2206,34 @@ ...@@ -2206,22 +2206,34 @@
}; };
var generalSelectCompanyExtraText = function(){ var generalSelectCompanyExtraText = function(){
$scope.regFinancialAccountingTypeList.map(function(value,index){ if($scope.selectCompanyExtra.smallMeagerProfit!=null){
if (value.code === $scope.selectCompanyExtra.regFinancialAccountingType) {
$scope.selectCompanyExtra.regFinancialAccountingType = value.type;
return;
}
});
$scope.selectCompanyExtra.smallMeagerProfit = $scope.selectCompanyExtra.smallMeagerProfit?"是":"否"; $scope.selectCompanyExtra.smallMeagerProfit = $scope.selectCompanyExtra.smallMeagerProfit?"是":"否";
}
if($scope.selectCompanyExtra.listedCompany!=null){
$scope.selectCompanyExtra.listedCompany = $scope.selectCompanyExtra.listedCompany?"是":"否"; $scope.selectCompanyExtra.listedCompany = $scope.selectCompanyExtra.listedCompany?"是":"否";
}
if($scope.selectCompanyExtra.signTripartiteAgreement!=null){
$scope.selectCompanyExtra.signTripartiteAgreement = $scope.selectCompanyExtra.signTripartiteAgreement =
$scope.selectCompanyExtra.signTripartiteAgreement?"是":"否"; $scope.selectCompanyExtra.signTripartiteAgreement?"是":"否";
}
if($scope.selectCompanyExtra.completeRecordTotalInstitutions!=null){
$scope.selectCompanyExtra.completeRecordTotalInstitutions = $scope.selectCompanyExtra.completeRecordTotalInstitutions =
$scope.selectCompanyExtra.completeRecordTotalInstitutions?"是":"否"; $scope.selectCompanyExtra.completeRecordTotalInstitutions?"是":"否";
}
if($scope.selectCompanyExtra.regFinancialAccountingType!=null){
$scope.regFinancialAccountingTypeList.map(function(value,index){
if (value.code === $scope.selectCompanyExtra.regFinancialAccountingType) {
$scope.selectCompanyExtra.regFinancialAccountingType = value.type;
return;
}
});
}
}; };
var generalSelectCompanyText = function(){ var generalSelectCompanyText = function(){
if($scope.selectCompany.engageNationalProhibitIndustry!=null){
$scope.selectCompany.engageNationalProhibitIndustry = $scope.selectCompany.engageNationalProhibitIndustry?"是":"否"; $scope.selectCompany.engageNationalProhibitIndustry = $scope.selectCompany.engageNationalProhibitIndustry?"是":"否";
}
}; };
// 添加或者编辑机构成功之后,刷新当前页面的数据 // 添加或者编辑机构成功之后,刷新当前页面的数据
...@@ -2232,7 +2244,6 @@ ...@@ -2232,7 +2244,6 @@
} else { } else {
$scope.organizationId = null; $scope.organizationId = null;
} }
initOrg(); initOrg();
$scope.isOrgUpdate = false; $scope.isOrgUpdate = false;
} }
......
...@@ -91,104 +91,9 @@ ...@@ -91,104 +91,9 @@
style="margin-top: 30px;"> style="margin-top: 30px;">
</div> </div>
</div> </div>
</div> <div class="page-footer">
<ack-pagination page-options="pagingOptions"
refresh-table="refreshConfigGrid()"></ack-pagination>
<div class="error-info-wrapper" id="error-info-wrapper" ng-show="showErrorTable">
<div ui-grid="gridOptionsErrorMsg" style="width:100%;" ng-style="getErrorGridHeight()"></div>
</div>
<div>
<div ng-show="showErrorTable" id="content-resizer"
resizer="horizontal"
resizer-height="6"
bottom-min="0"
bottom-max="400"
resizer-top="#balance-ouput-grid-wrapper"
resizer-bottom="#error-info-wrapper">
<div id="topIcon" ng-click="toggleErrorTab()">
<img src="../../../../app-resources/images/collapse.png" />
</div>
</div>
</div>
</div>
<!--期间验证明细-->
<div class="period-validation-modal">
<div class="modal fade" id="periodValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center;" id="gridPeriodValidation" dx-data-grid="gridPeriodOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--重复验证明细-->
<div class="duplicate-validation-modal">
<div class="modal fade" id="duplicatedValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center; " id="gridDuplicatedValidation" dx-data-grid="gridDuplicatedOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="BtnDelete" ng-click="deleteDupData()" ng-disabled="!hasEditPermission"></button>
<button type="button" class="btn btn-customer" translate="ButtonCancel" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--错误验证信息-->
<div class="error-list-modal">
<div class="modal fade" id="errorListModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 720px; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ImportErrorPopUpTitle' | translate}}
</div>
</div>
<div class="modal-body">
{{'ImportErrorPopUpErrorDetail' | translate}}:
<br />
<table>
<thead>
<tr>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpNoCol' | translate}}</th>
<th width="20%">{{'ImportErrorPopUpErrorTypeCol' | translate}}</th>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpErrorCountCol' | translate}}</th>
<th width="6%">{{'ImportErrorPopUpErrorDescCol' | translate}}</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="error in errorMsgMap track by $index">
<td width="10%" style="text-align:center;">{{$index + 1}}</td>
<td width="20%">{{error.errorType}}</td>
<td width="10%" style="text-align:center;">{{error.errorCount}}</td>
<td width="60%" ng-bind-html="error.errorContent"></td>
</tr>
</tbody>
</table>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div> </div>
</div> </div>
</div> </div>
...@@ -211,10 +116,8 @@ ...@@ -211,10 +116,8 @@
<div class="modal-footer"> <div class="modal-footer">
<button type="button" class="btn btn-primary" ng-click="deleteTbData()">{{'Confirm' | translate}}</button> <button type="button" class="btn btn-primary" ng-click="deleteTbData()">{{'Confirm' | translate}}</button>
</div> </div>
</script> </script>
<vat-operate-log period="period" module-type="moduleid" is-show="isShowLog"></vat-operate-log>
</div> </div>
......
...@@ -760,22 +760,6 @@ ...@@ -760,22 +760,6 @@
}); });
}; };
//显示图标
var errorLevelToString = function (errorLevel) {
if (errorLevel === 0) {
return '/app-resources/images/vat/error.png';
}
if (errorLevel === 1) {
return '/app-resources/images/vat/warning.png';
}
if (errorLevel === 2) {
return '/app-resources/images/vat/tips.png';
}
else {
return '/app-resources/images/vat/tips.png';
}
}
//刷新操作 //刷新操作
var refreshTbData = function () { var refreshTbData = function () {
logDto.ID = PWC.newGuid(); logDto.ID = PWC.newGuid();
...@@ -825,27 +809,11 @@ ...@@ -825,27 +809,11 @@
} }
}; };
var loadImportBSStatusInfoDatagrid = function () {
var getErrorGridHeight = function () {
if ($scope.isLoadComplete) {
var y = $("#error-info-wrapper").height();
// Enough space
if (y > constant.UIGrid.gapHeight) {
y = y - constant.UIGrid.gapHeight;
return { height: y + "px" };
} else {
return { height: '0px' };
}
}
return {};
};
var loadImportPLStatusInfoDatagrid = function () {
$scope.importPLStatusGridOptions = { $scope.importPLStatusGridOptions = {
bindingOptions: { bindingOptions: {
dataSource: 'ImportPLStatusGridSource' dataSource: 'ImportBSStatusGridSource'
}, },
showBorders: true, showBorders: true,
columns: [{ columns: [{
...@@ -896,7 +864,7 @@ ...@@ -896,7 +864,7 @@
} }
], ],
onContentReady: function (e) { onContentReady: function (e) {
$scope.accountingRateListInstance = e.component; $scope.pLStatusInstance = e.component;
var totalCount = e.component.totalCount(); var totalCount = e.component.totalCount();
if (totalCount > 0) { if (totalCount > 0) {
$scope.totalCount = totalCount; $scope.totalCount = totalCount;
...@@ -931,85 +899,26 @@ ...@@ -931,85 +899,26 @@
getImportBSStatus(); getImportBSStatus();
}; };
var getImportBSStatus = function () { //刷新页面
vatImportService.displayImportLog(constant.importFileType.balanceSheet).success(function (data) { $scope.refreshConfigGrid = function () {
if (data) {
$scope.ImportPLStatusGridSource = data;
for (var i = 1; i <= $scope.AccountingRateGridSource.length; i++) {
$scope.AccountingRateGridSource[i - 1].index = i;
}
}
});
};
var initImportPLStatusFromDB = function () {
getImportBSStatus(); getImportBSStatus();
}; };
//获取验证信息 var getImportBSStatus = function () {
var GetValidationList = function () { vatImportService.displayImportLog($scope.pagingOptions,constant.importFileType.balanceSheet).success(function (data) {
vatImportService.getServiceValidationList($scope.validationType, $scope.period, $scope.serviceTypeId, $scope.projectID).success(function (data) { if (data && data.list) {
if (data.length > 0) { $scope.ImportBSStatusGridSource = data.list;
var index = 1; $scope.pagingOptions.totalItems = data.pageInfo.totalCount;
data.forEach(function (v) { }else {
v.index = index++; SweetAlert.error($translate.instant('SystemError'));
});
$scope.errorList = data;
$scope.gridOptionsErrorMsg.data = data;
showErrTab();
$scope.toggleErrorTab();
$scope.showErrorTable = true;
}
else {
$scope.errorList = [];
$scope.gridOptionsErrorMsg.data = [];
$scope.showErrorTable = false;
$scope.ImportErrorTab = false;
$scope.ImportErrorTag = false;
} }
}).error(function () {
SweetAlert.error($translate.instant('PleaseContactAdministrator'));
}); });
}
//显示验证信息
var toggleErrorTab = function () {
$scope.ImportErrorTag = !$scope.ImportErrorTag;
// topIcon and content-resize gapBottom 15px
if (!$scope.ImportErrorTag) {
setErrorWrapCssDefault();
} else {
if (parseInt($('#content-resizer').css('bottom')) < 100) {
$('#content-resizer').css('bottom', '150px');
$('#topIcon').css({ bottom: '-381px' });
$('.error-info-wrapper').css('height', '150px');
}
}
};
var setErrorWrapCssDefault = function () {
$('#content-resizer').css('bottom', '0px');
$('#topIcon').css({ bottom: '-501px' });
$('.error-info-wrapper').css('height', '0px');
}; };
var initImportPLStatusFromDB = function () {
var showErrTab = function() { getImportBSStatus();
$scope.ImportErrorTab = true;
$scope.ImportErrorTag = true;
$scope.errorMsg = $translate.instant('ImportErrorMsg').formatObj({ "NumberOfError": $scope.errorList.length });
}; };
//加载文档后操作 //加载文档后操作
var initImportFile = function (fileName) { var initImportFile = function (fileName) {
var arr = fileName.name.split('.'); var arr = fileName.name.split('.');
...@@ -1233,26 +1142,24 @@ ...@@ -1233,26 +1142,24 @@
ele1.datepicker("setDate", $scope.selectedDate); ele1.datepicker("setDate", $scope.selectedDate);
}; };
//开始 var initParam = function () {
(function initialize() {
$log.debug('ImportTBController.ctor()...');
checkUserOrganizationPermissionList();
$scope.doUploadBS = doUploadBS; $scope.doUploadBS = doUploadBS;
$scope.downloadTemplate = downloadTemplate; $scope.downloadTemplate = downloadTemplate;
$scope.refreshTbData = refreshTbData; $scope.refreshTbData = refreshTbData;
$scope.initPagingControl = initPagingControl; $scope.initPagingControl = initPagingControl;
$scope.setButtonWrapStyle = setButtonWrapStyle; $scope.setButtonWrapStyle = setButtonWrapStyle;
$scope.errorLevelToString = errorLevelToString;
$scope.getGridHeight = getGridHeight; $scope.getGridHeight = getGridHeight;
$scope.getErrorGridHeight = getErrorGridHeight;
$scope.toggleErrorTab = toggleErrorTab;
$scope.showOperateLogPop = showOperateLogPop; $scope.showOperateLogPop = showOperateLogPop;
$scope.setGridStyle = setGridStyle; $scope.setGridStyle = setGridStyle;
};
//开始
(function initialize() {
$log.debug('ImportTBController.ctor()...');
checkUserOrganizationPermissionList();
getUserPermission(); getUserPermission();
initParam();
loadImportPLStatusInfoDatagrid(); loadImportBSStatusInfoDatagrid();
initDatePicker(); initDatePicker();
$scope.$watch('importExcelFile', function (newValue, oldValue) { $scope.$watch('importExcelFile', function (newValue, oldValue) {
......
...@@ -68,104 +68,9 @@ ...@@ -68,104 +68,9 @@
style="margin-top: 30px;"> style="margin-top: 30px;">
</div> </div>
</div> </div>
</div> <div class="page-footer">
<ack-pagination page-options="pagingOptions"
refresh-table="refreshConfigGrid()"></ack-pagination>
<div class="error-info-wrapper" id="error-info-wrapper" ng-show="showErrorTable">
<div ui-grid="gridOptionsErrorMsg" style="width:100%;" ng-style="getErrorGridHeight()"></div>
</div>
<div>
<div ng-show="showErrorTable" id="content-resizer"
resizer="horizontal"
resizer-height="6"
bottom-min="0"
bottom-max="400"
resizer-top="#balance-ouput-grid-wrapper"
resizer-bottom="#error-info-wrapper">
<div id="topIcon" ng-click="toggleErrorTab()">
<img src="../../../../app-resources/images/collapse.png" />
</div>
</div>
</div>
</div>
<!--期间验证明细-->
<div class="period-validation-modal">
<div class="modal fade" id="periodValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center;" id="gridPeriodValidation" dx-data-grid="gridPeriodOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--重复验证明细-->
<div class="duplicate-validation-modal">
<div class="modal fade" id="duplicatedValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center; " id="gridDuplicatedValidation" dx-data-grid="gridDuplicatedOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="BtnDelete" ng-click="deleteDupData()" ng-disabled="!hasEditPermission"></button>
<button type="button" class="btn btn-customer" translate="ButtonCancel" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--错误验证信息-->
<div class="error-list-modal">
<div class="modal fade" id="errorListModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 720px; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ImportErrorPopUpTitle' | translate}}
</div>
</div>
<div class="modal-body">
{{'ImportErrorPopUpErrorDetail' | translate}}:
<br />
<table>
<thead>
<tr>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpNoCol' | translate}}</th>
<th width="20%">{{'ImportErrorPopUpErrorTypeCol' | translate}}</th>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpErrorCountCol' | translate}}</th>
<th width="6%">{{'ImportErrorPopUpErrorDescCol' | translate}}</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="error in errorMsgMap track by $index">
<td width="10%" style="text-align:center;">{{$index + 1}}</td>
<td width="20%">{{error.errorType}}</td>
<td width="10%" style="text-align:center;">{{error.errorCount}}</td>
<td width="60%" ng-bind-html="error.errorContent"></td>
</tr>
</tbody>
</table>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div> </div>
</div> </div>
</div> </div>
...@@ -184,11 +89,9 @@ ...@@ -184,11 +89,9 @@
</div> </div>
</div> </div>
</div> </div>
<div class="modal-footer"> <div class="modal-footer">
<button type="button" class="btn btn-primary" ng-click="deleteTbData()">{{'Confirm' | translate}}</button> <button type="button" class="btn btn-primary" ng-click="deleteTbData()">{{'Confirm' | translate}}</button>
</div> </div>
</script> </script>
<vat-operate-log period="period" module-type="moduleid" is-show="isShowLog"></vat-operate-log> <vat-operate-log period="period" module-type="moduleid" is-show="isShowLog"></vat-operate-log>
......
...@@ -68,104 +68,9 @@ ...@@ -68,104 +68,9 @@
style="margin-top: 30px;"> style="margin-top: 30px;">
</div> </div>
</div> </div>
</div> <div class="page-footer">
<ack-pagination page-options="pagingOptions"
refresh-table="refreshConfigGrid()"></ack-pagination>
<div class="error-info-wrapper" id="error-info-wrapper" ng-show="showErrorTable">
<div ui-grid="gridOptionsErrorMsg" style="width:100%;" ng-style="getErrorGridHeight()"></div>
</div>
<div>
<div ng-show="showErrorTable" id="content-resizer"
resizer="horizontal"
resizer-height="6"
bottom-min="0"
bottom-max="400"
resizer-top="#balance-ouput-grid-wrapper"
resizer-bottom="#error-info-wrapper">
<div id="topIcon" ng-click="toggleErrorTab()">
<img src="../../../../app-resources/images/collapse.png" />
</div>
</div>
</div>
</div>
<!--期间验证明细-->
<div class="period-validation-modal">
<div class="modal fade" id="periodValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center;" id="gridPeriodValidation" dx-data-grid="gridPeriodOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--重复验证明细-->
<div class="duplicate-validation-modal">
<div class="modal fade" id="duplicatedValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center; " id="gridDuplicatedValidation" dx-data-grid="gridDuplicatedOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="BtnDelete" ng-click="deleteDupData()" ng-disabled="!hasEditPermission"></button>
<button type="button" class="btn btn-customer" translate="ButtonCancel" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--错误验证信息-->
<div class="error-list-modal">
<div class="modal fade" id="errorListModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 720px; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ImportErrorPopUpTitle' | translate}}
</div>
</div>
<div class="modal-body">
{{'ImportErrorPopUpErrorDetail' | translate}}:
<br />
<table>
<thead>
<tr>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpNoCol' | translate}}</th>
<th width="20%">{{'ImportErrorPopUpErrorTypeCol' | translate}}</th>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpErrorCountCol' | translate}}</th>
<th width="6%">{{'ImportErrorPopUpErrorDescCol' | translate}}</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="error in errorMsgMap track by $index">
<td width="10%" style="text-align:center;">{{$index + 1}}</td>
<td width="20%">{{error.errorType}}</td>
<td width="10%" style="text-align:center;">{{error.errorCount}}</td>
<td width="60%" ng-bind-html="error.errorContent"></td>
</tr>
</tbody>
</table>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div> </div>
</div> </div>
</div> </div>
......
...@@ -42,13 +42,6 @@ ...@@ -42,13 +42,6 @@
</div> </div>
</div> </div>
<!--分页栏-->
<!--<div class="form-group page-form-group" ng-show="!fileName">
<div class="page-footer">
<ack-pagination page-options="pagingOptions" refresh-table="eventService.refreshInvoiceDataGrid()" hide-page-size-selector="false"></ack-pagination>
</div>
</div>-->
</form> </form>
<div class="dt-init-wrapper"> <div class="dt-init-wrapper">
...@@ -57,104 +50,9 @@ ...@@ -57,104 +50,9 @@
style="margin-top: 30px;"> style="margin-top: 30px;">
</div> </div>
</div> </div>
</div> <div class="page-footer">
<ack-pagination page-options="pagingOptions"
refresh-table="refreshConfigGrid()"></ack-pagination>
<div class="error-info-wrapper" id="error-info-wrapper" ng-show="showErrorTable">
<div ui-grid="gridOptionsErrorMsg" style="width:100%;" ng-style="getErrorGridHeight()"></div>
</div>
<div>
<div ng-show="showErrorTable" id="content-resizer"
resizer="horizontal"
resizer-height="6"
bottom-min="0"
bottom-max="400"
resizer-top="#balance-ouput-grid-wrapper"
resizer-bottom="#error-info-wrapper">
<div id="topIcon" ng-click="toggleErrorTab()">
<img src="../../../../app-resources/images/collapse.png" />
</div>
</div>
</div>
</div>
<!--期间验证明细-->
<div class="period-validation-modal">
<div class="modal fade" id="periodValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center;" id="gridPeriodValidation" dx-data-grid="gridPeriodOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--重复验证明细-->
<div class="duplicate-validation-modal">
<div class="modal fade" id="duplicatedValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center; " id="gridDuplicatedValidation" dx-data-grid="gridDuplicatedOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="BtnDelete" ng-click="deleteDupData()" ng-disabled="!hasEditPermission"></button>
<button type="button" class="btn btn-customer" translate="ButtonCancel" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--错误验证信息-->
<div class="error-list-modal">
<div class="modal fade" id="errorListModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 720px; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ImportErrorPopUpTitle' | translate}}
</div>
</div>
<div class="modal-body">
{{'ImportErrorPopUpErrorDetail' | translate}}:
<br />
<table>
<thead>
<tr>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpNoCol' | translate}}</th>
<th width="20%">{{'ImportErrorPopUpErrorTypeCol' | translate}}</th>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpErrorCountCol' | translate}}</th>
<th width="6%">{{'ImportErrorPopUpErrorDescCol' | translate}}</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="error in errorMsgMap track by $index">
<td width="10%" style="text-align:center;">{{$index + 1}}</td>
<td width="20%">{{error.errorType}}</td>
<td width="10%" style="text-align:center;">{{error.errorCount}}</td>
<td width="60%" ng-bind-html="error.errorContent"></td>
</tr>
</tbody>
</table>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div> </div>
</div> </div>
</div> </div>
......
...@@ -76,13 +76,6 @@ ...@@ -76,13 +76,6 @@
</div> </div>
</div> </div>
</div> </div>
<!--分页栏-->
<!--<div class="form-group page-form-group" ng-show="!fileName">
<div class="page-footer">
<ack-pagination page-options="pagingOptions" refresh-table="eventService.refreshInvoiceDataGrid()" hide-page-size-selector="false"></ack-pagination>
</div>
</div>-->
</form> </form>
<div class="dt-init-wrapper"> <div class="dt-init-wrapper">
...@@ -91,108 +84,12 @@ ...@@ -91,108 +84,12 @@
style="margin-top: 30px;"> style="margin-top: 30px;">
</div> </div>
</div> </div>
</div> <div class="page-footer">
<ack-pagination page-options="pagingOptions"
refresh-table="refreshConfigGrid()"></ack-pagination>
<div class="error-info-wrapper" id="error-info-wrapper" ng-show="showErrorTable">
<div ui-grid="gridOptionsErrorMsg" style="width:100%;" ng-style="getErrorGridHeight()"></div>
</div>
<div>
<div ng-show="showErrorTable" id="content-resizer"
resizer="horizontal"
resizer-height="6"
bottom-min="0"
bottom-max="400"
resizer-top="#balance-ouput-grid-wrapper"
resizer-bottom="#error-info-wrapper">
<div id="topIcon" ng-click="toggleErrorTab()">
<img src="../../../../app-resources/images/collapse.png" />
</div>
</div>
</div>
</div>
<!--期间验证明细-->
<div class="period-validation-modal">
<div class="modal fade" id="periodValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center;" id="gridPeriodValidation" dx-data-grid="gridPeriodOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--重复验证明细-->
<div class="duplicate-validation-modal">
<div class="modal fade" id="duplicatedValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center; " id="gridDuplicatedValidation" dx-data-grid="gridDuplicatedOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="BtnDelete" ng-click="deleteDupData()" ng-disabled="!hasEditPermission"></button>
<button type="button" class="btn btn-customer" translate="ButtonCancel" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--错误验证信息-->
<div class="error-list-modal">
<div class="modal fade" id="errorListModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 720px; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ImportErrorPopUpTitle' | translate}}
</div>
</div>
<div class="modal-body">
{{'ImportErrorPopUpErrorDetail' | translate}}:
<br />
<table>
<thead>
<tr>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpNoCol' | translate}}</th>
<th width="20%">{{'ImportErrorPopUpErrorTypeCol' | translate}}</th>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpErrorCountCol' | translate}}</th>
<th width="6%">{{'ImportErrorPopUpErrorDescCol' | translate}}</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="error in errorMsgMap track by $index">
<td width="10%" style="text-align:center;">{{$index + 1}}</td>
<td width="20%">{{error.errorType}}</td>
<td width="10%" style="text-align:center;">{{error.errorCount}}</td>
<td width="60%" ng-bind-html="error.errorContent"></td>
</tr>
</tbody>
</table>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div> </div>
</div> </div>
</div> </div>
<!-- 期间选择弹出框 --> <!-- 期间选择弹出框 -->
<script type="text/ng-template" id="tb-model-period-dropdown.html" class="tb-model-period-dropdow-popup"> <script type="text/ng-template" id="tb-model-period-dropdown.html" class="tb-model-period-dropdow-popup">
<div class="modal-header"> <div class="modal-header">
......
...@@ -53,13 +53,6 @@ ...@@ -53,13 +53,6 @@
</div> </div>
</div> </div>
</div> </div>
<!--分页栏-->
<!--<div class="form-group page-form-group" ng-show="!fileName">
<div class="page-footer">
<ack-pagination page-options="pagingOptions" refresh-table="eventService.refreshInvoiceDataGrid()" hide-page-size-selector="false"></ack-pagination>
</div>
</div>-->
</form> </form>
<div class="dt-init-wrapper"> <div class="dt-init-wrapper">
...@@ -68,108 +61,12 @@ ...@@ -68,108 +61,12 @@
style="margin-top: 30px;"> style="margin-top: 30px;">
</div> </div>
</div> </div>
</div> <div class="page-footer">
<ack-pagination page-options="pagingOptions"
refresh-table="refreshConfigGrid()"></ack-pagination>
<div class="error-info-wrapper" id="error-info-wrapper" ng-show="showErrorTable">
<div ui-grid="gridOptionsErrorMsg" style="width:100%;" ng-style="getErrorGridHeight()"></div>
</div>
<div>
<div ng-show="showErrorTable" id="content-resizer"
resizer="horizontal"
resizer-height="6"
bottom-min="0"
bottom-max="400"
resizer-top="#balance-ouput-grid-wrapper"
resizer-bottom="#error-info-wrapper">
<div id="topIcon" ng-click="toggleErrorTab()">
<img src="../../../../app-resources/images/collapse.png" />
</div>
</div>
</div>
</div>
<!--期间验证明细-->
<div class="period-validation-modal">
<div class="modal fade" id="periodValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center;" id="gridPeriodValidation" dx-data-grid="gridPeriodOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--重复验证明细-->
<div class="duplicate-validation-modal">
<div class="modal fade" id="duplicatedValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center; " id="gridDuplicatedValidation" dx-data-grid="gridDuplicatedOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="BtnDelete" ng-click="deleteDupData()" ng-disabled="!hasEditPermission"></button>
<button type="button" class="btn btn-customer" translate="ButtonCancel" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--错误验证信息-->
<div class="error-list-modal">
<div class="modal fade" id="errorListModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 720px; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ImportErrorPopUpTitle' | translate}}
</div>
</div>
<div class="modal-body">
{{'ImportErrorPopUpErrorDetail' | translate}}:
<br />
<table>
<thead>
<tr>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpNoCol' | translate}}</th>
<th width="20%">{{'ImportErrorPopUpErrorTypeCol' | translate}}</th>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpErrorCountCol' | translate}}</th>
<th width="6%">{{'ImportErrorPopUpErrorDescCol' | translate}}</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="error in errorMsgMap track by $index">
<td width="10%" style="text-align:center;">{{$index + 1}}</td>
<td width="20%">{{error.errorType}}</td>
<td width="10%" style="text-align:center;">{{error.errorCount}}</td>
<td width="60%" ng-bind-html="error.errorContent"></td>
</tr>
</tbody>
</table>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div> </div>
</div> </div>
</div> </div>
<!-- 期间选择弹出框 --> <!-- 期间选择弹出框 -->
<script type="text/ng-template" id="tb-model-period-dropdown.html" class="tb-model-period-dropdow-popup"> <script type="text/ng-template" id="tb-model-period-dropdown.html" class="tb-model-period-dropdow-popup">
<div class="modal-header"> <div class="modal-header">
......
...@@ -8,11 +8,7 @@ ...@@ -8,11 +8,7 @@
, projectService, vatCommonService,orgService,templateService) { , projectService, vatCommonService,orgService,templateService) {
'use strict'; 'use strict';
var successCount = 0;
var uploadUrl = apiInterceptor.vatWebApiHostUrl + '/FileUpload/NewFile';
var resumable = true;
var comment = vatSessionService.project.name + " " + vatSessionService.project.year + "年" + vatSessionService.month + "月"; var comment = vatSessionService.project.name + " " + vatSessionService.project.year + "年" + vatSessionService.month + "月";
var servicePeriods = [];
$scope.period = $scope.periodId; $scope.period = $scope.periodId;
$scope.moduleid = enums.vatModuleEnum.Import_TrialBalance; $scope.moduleid = enums.vatModuleEnum.Import_TrialBalance;
$scope.chunkSize = 100000; $scope.chunkSize = 100000;
...@@ -98,19 +94,6 @@ ...@@ -98,19 +94,6 @@
projectId: $scope.projectID projectId: $scope.projectID
}; };
$scope.totalData = {
totalNumber: 0,
begDebitTotal: 0,
begCreditTotal: 0,
endDebitTotal: 0,
endCreditTotal: 0,
begBalTotal: 0,
endBalTotal: 0,
debitTotal: 0,
creditTotal: 0,
};
//分页获取数据 //分页获取数据
$scope.eventService = { $scope.eventService = {
refreshInvoiceDataGrid: function () { refreshInvoiceDataGrid: function () {
...@@ -118,39 +101,6 @@ ...@@ -118,39 +101,6 @@
} }
}; };
//转换没有选中的列值
var undefinedStringToNull = function (i, stringName) {
var data = $scope.sheetData.dataList[i][$.inArray($translate.instant(stringName), $scope.selectedMappingList)];
if (_.isUndefined(data)) {
return null;
}
else {
if (PWC.isNullOrEmpty(data)) {
return "";
}
else {
return data;
}
}
}
//转换没有选中的列值
var undefinedNumToNull = function (i, stringName) {
var data = $scope.sheetData.dataList[i][$.inArray($translate.instant(stringName), $scope.selectedMappingList)];
if (_.isUndefined(data)) {
return null;
}
else {
if (PWC.isNullOrEmpty(data)) {
return 0;
}
else {
return data;
}
}
};
var downloadTemplate = function () { var downloadTemplate = function () {
templateService.downloadTemplate(constant.importFileType.invoiceRecord).success(function (data, status, headers) { templateService.downloadTemplate(constant.importFileType.invoiceRecord).success(function (data, status, headers) {
var octetStreamMime = 'application/octet-stream'; var octetStreamMime = 'application/octet-stream';
...@@ -272,22 +222,6 @@ ...@@ -272,22 +222,6 @@
}); });
}; };
//显示图标
var errorLevelToString = function (errorLevel) {
if (errorLevel === 0) {
return '/app-resources/images/vat/error.png';
}
if (errorLevel === 1) {
return '/app-resources/images/vat/warning.png';
}
if (errorLevel === 2) {
return '/app-resources/images/vat/tips.png';
}
else {
return '/app-resources/images/vat/tips.png';
}
};
var getGridHeight = function () { var getGridHeight = function () {
if ($scope.isLoadComplete) { if ($scope.isLoadComplete) {
return { height: ($('.balance-ouput-grid-wrapper').height()) + "px" }; return { height: ($('.balance-ouput-grid-wrapper').height()) + "px" };
...@@ -297,22 +231,6 @@ ...@@ -297,22 +231,6 @@
} }
}; };
var getErrorGridHeight = function () {
if ($scope.isLoadComplete) {
var y = $("#error-info-wrapper").height();
// Enough space
if (y > constant.UIGrid.gapHeight) {
y = y - constant.UIGrid.gapHeight;
return { height: y + "px" };
} else {
return { height: '0px' };
}
}
return {};
};
var loadImportIRStatusInfoDatagrid = function () { var loadImportIRStatusInfoDatagrid = function () {
$scope.importIRStatusGridOptions = { $scope.importIRStatusGridOptions = {
...@@ -404,53 +322,22 @@ ...@@ -404,53 +322,22 @@
}; };
var getImportIRStatus = function () { var getImportIRStatus = function () {
vatImportService.displayImportLog(constant.importFileType.invoiceRecord).success(function (data) { vatImportService.displayImportLog($scope.pagingOptions,constant.importFileType.invoiceRecord).success(function (data) {
if (data) { if (data && data.list) {
$scope.ImportIRStatusGridSource = data; $scope.ImportIRStatusGridSource = data.list;
for (var i = 1; i <= $scope.ImportIRStatusGridSource.length; i++) { $scope.pagingOptions.totalItems = data.pageInfo.totalCount;
$scope.ImportIRStatusGridSource[i - 1].index = i; }else {
} SweetAlert.error($translate.instant('SystemError'));
} }
}); });
}; };
var initImportIRStatusFromDB = function () { //刷新页面
$scope.refreshConfigGrid = function () {
getImportIRStatus(); getImportIRStatus();
}; };
//显示验证信息
var toggleErrorTab = function () {
$scope.ImportErrorTag = !$scope.ImportErrorTag;
// topIcon and content-resize gapBottom 15px
if (!$scope.ImportErrorTag) {
setErrorWrapCssDefault();
} else {
if (parseInt($('#content-resizer').css('bottom')) < 100) {
$('#content-resizer').css('bottom', '150px');
$('#topIcon').css({ bottom: '-381px' });
$('.error-info-wrapper').css('height', '150px');
}
}
};
var setErrorWrapCssDefault = function () {
$('#content-resizer').css('bottom', '0px');
$('#topIcon').css({ bottom: '-501px' });
$('.error-info-wrapper').css('height', '0px');
};
var showErrTab = function() {
$scope.ImportErrorTab = true;
$scope.ImportErrorTag = true;
$scope.errorMsg = $translate.instant('ImportErrorMsg').formatObj({ "NumberOfError": $scope.errorList.length });
};
//加载文档后操作 //加载文档后操作
var initImportFile = function (fileName) { var initImportFile = function (fileName) {
...@@ -588,22 +475,21 @@ ...@@ -588,22 +475,21 @@
}); });
}; };
//开始 var initParam = function () {
(function initialize() {
$log.debug('ImportTBController.ctor()...');
checkUserOrganizationPermissionList();
$scope.doUploadIR = doUploadIR; $scope.doUploadIR = doUploadIR;
$scope.downloadTemplate = downloadTemplate; $scope.downloadTemplate = downloadTemplate;
$scope.initPagingControl = initPagingControl; $scope.initPagingControl = initPagingControl;
$scope.setButtonWrapStyle = setButtonWrapStyle; $scope.setButtonWrapStyle = setButtonWrapStyle;
$scope.errorLevelToString = errorLevelToString;
$scope.getGridHeight = getGridHeight; $scope.getGridHeight = getGridHeight;
$scope.getErrorGridHeight = getErrorGridHeight;
$scope.toggleErrorTab = toggleErrorTab;
$scope.showOperateLogPop = showOperateLogPop; $scope.showOperateLogPop = showOperateLogPop;
$scope.setGridStyle = setGridStyle; $scope.setGridStyle = setGridStyle;
};
//开始
(function initialize() {
$log.debug('ImportTBController.ctor()...');
checkUserOrganizationPermissionList();
initParam();
getUserPermission(); getUserPermission();
initCompanyList(); initCompanyList();
loadImportIRStatusInfoDatagrid(); loadImportIRStatusInfoDatagrid();
......
...@@ -76,13 +76,6 @@ ...@@ -76,13 +76,6 @@
</div> </div>
</div> </div>
</div> </div>
<!--分页栏-->
<!--<div class="form-group page-form-group" ng-show="!fileName">
<div class="page-footer">
<ack-pagination page-options="pagingOptions" refresh-table="eventService.refreshInvoiceDataGrid()" hide-page-size-selector="false"></ack-pagination>
</div>
</div>-->
</form> </form>
<div class="dt-init-wrapper"> <div class="dt-init-wrapper">
...@@ -91,108 +84,12 @@ ...@@ -91,108 +84,12 @@
style="margin-top: 30px;"> style="margin-top: 30px;">
</div> </div>
</div> </div>
</div> <div class="page-footer">
<ack-pagination page-options="pagingOptions"
refresh-table="refreshConfigGrid()"></ack-pagination>
<div class="error-info-wrapper" id="error-info-wrapper" ng-show="showErrorTable">
<div ui-grid="gridOptionsErrorMsg" style="width:100%;" ng-style="getErrorGridHeight()"></div>
</div>
<div>
<div ng-show="showErrorTable" id="content-resizer"
resizer="horizontal"
resizer-height="6"
bottom-min="0"
bottom-max="400"
resizer-top="#balance-ouput-grid-wrapper"
resizer-bottom="#error-info-wrapper">
<div id="topIcon" ng-click="toggleErrorTab()">
<img src="../../../../app-resources/images/collapse.png" />
</div>
</div>
</div>
</div>
<!--期间验证明细-->
<div class="period-validation-modal">
<div class="modal fade" id="periodValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center;" id="gridPeriodValidation" dx-data-grid="gridPeriodOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--重复验证明细-->
<div class="duplicate-validation-modal">
<div class="modal fade" id="duplicatedValidationModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 75%; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ErrorDetails' | translate}}
</div>
</div>
<div class="modal-body">
<div style="border: 1px solid #959595; text-align: center; " id="gridDuplicatedValidation" dx-data-grid="gridDuplicatedOptions"></div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="BtnDelete" ng-click="deleteDupData()" ng-disabled="!hasEditPermission"></button>
<button type="button" class="btn btn-customer" translate="ButtonCancel" data-dismiss="modal"></button>
</div>
</div>
</div>
</div>
</div>
<!--错误验证信息-->
<div class="error-list-modal">
<div class="modal fade" id="errorListModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog" style="width: 720px; height: 200px;" role="document">
<div class="modal-content">
<div class="modal-header">
<div class="modal-title">
{{'ImportErrorPopUpTitle' | translate}}
</div>
</div>
<div class="modal-body">
{{'ImportErrorPopUpErrorDetail' | translate}}:
<br />
<table>
<thead>
<tr>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpNoCol' | translate}}</th>
<th width="20%">{{'ImportErrorPopUpErrorTypeCol' | translate}}</th>
<th width="10%" style="text-align:center;">{{'ImportErrorPopUpErrorCountCol' | translate}}</th>
<th width="6%">{{'ImportErrorPopUpErrorDescCol' | translate}}</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="error in errorMsgMap track by $index">
<td width="10%" style="text-align:center;">{{$index + 1}}</td>
<td width="20%">{{error.errorType}}</td>
<td width="10%" style="text-align:center;">{{error.errorCount}}</td>
<td width="60%" ng-bind-html="error.errorContent"></td>
</tr>
</tbody>
</table>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" translate="Confirm" data-dismiss="modal"></button>
</div>
</div>
</div> </div>
</div> </div>
</div> </div>
<!-- 期间选择弹出框 --> <!-- 期间选择弹出框 -->
<script type="text/ng-template" id="tb-model-period-dropdown.html" class="tb-model-period-dropdow-popup"> <script type="text/ng-template" id="tb-model-period-dropdown.html" class="tb-model-period-dropdow-popup">
<div class="modal-header"> <div class="modal-header">
......
...@@ -151,7 +151,8 @@ constant.OperateLogType = { ...@@ -151,7 +151,8 @@ constant.OperateLogType = {
} }
constant.page = { constant.page = {
pageSize: 10 pageSize: 10,
logPageSize : 20
} }
constant.page.pageSizeArrary = [10, 20, 50, 100, 5]; constant.page.pageSizeArrary = [10, 20, 50, 100, 5];
...@@ -1422,18 +1423,20 @@ constant.importFileType = { ...@@ -1422,18 +1423,20 @@ constant.importFileType = {
coupaPurchasingReport: 6, coupaPurchasingReport: 6,
invoiceData: 7, invoiceData: 7,
certifiedInvoicesList: 8, certifiedInvoicesList: 8,
invoiceRecord: 9 invoiceRecord: 9,
ExtractFinancialData: 10,
ExtractInvoiceData: 11
}; };
constant.fileTypeList = [ constant.fileTypeList = [
{code:0,type:"月度科目余额表"}, {code:0,type:"月度科目余额表"},
{code:1,type:"日记账"}, {code:1,type:"日记账"},
{code:2,type:"资产负债表PRC"}, {code:2,type:"资产负债表PRC"},
{code:2,type:"利润表PRC"}, {code:3,type:"利润表PRC"},
{code:2,type:"资产负债表"}, {code:4,type:"资产负债表"},
{code:2,type:"利润表"}, {code:5,type:"利润表"},
{code:2,type:"直接法现金流量表"}, {code:6,type:"直接法现金流量表"},
{code:2,type:"所有者权益变动表和汇率表"} {code:7,type:"所有者权益变动表和汇率表"}
]; ];
......
...@@ -400,8 +400,8 @@ ...@@ -400,8 +400,8 @@
/***************************************批量数据导入服务(真) start**************************************************************/ /***************************************批量数据导入服务(真) start**************************************************************/
displayImportLog: function (type) { displayImportLog: function (pageInfo, type) {
return $http.get('/DataImport/displayImportLog?type=' + type, apiConfig.create()); return $http.post('/DataImport/displayImportLog', {pageInfo: pageInfo, type: type}, apiConfig.create());
} }
/***************************************批量数据导入服务(真) end**************************************************************/ /***************************************批量数据导入服务(真) end**************************************************************/
......
...@@ -112,5 +112,14 @@ webservices.factory('dataImportService', ['$http', 'apiConfig', function ($http, ...@@ -112,5 +112,14 @@ webservices.factory('dataImportService', ['$http', 'apiConfig', function ($http,
/***************************************cit services end**************************************************************/ /***************************************cit services end**************************************************************/
/***************************************call ApiServices start**************************************************************/
callExtractFinancialData: function (orgIds, period,dataTypes) {
return $http.post('/DataImport/callExtractFinancialData',{ orgIds: orgIds, period: period,dataTypes:dataTypes }, apiConfig.create());
},
callExtractInvoiceData: function (orgIds, period,dataTypes) {
return $http.post('/DataImport/callExtractInvoiceData', { orgIds: orgIds, period: period,dataTypes:dataTypes }, apiConfig.create());
}
/***************************************call ApiServices end**************************************************************/
}; };
}]); }]);
\ No newline at end of file
dataImpModule.directive('extractInvoiceData', ['$log', dataImpModule.directive('extractFinancialData', ['$log',
function ($log) { function ($log) {
'use strict'; 'use strict';
return { return {
restrict: 'E', restrict: 'E',
templateUrl: '/app/dataImport/data-extraction/extract-invoice-data/extract-invoice-data.html' + '?_=' + Math.random(), templateUrl: '/app/dataImport/data-extraction/extract-financial-data/extract-financial-data.html' + '?_=' + Math.random(),
scope: { scope: {
serviceTypeId: "=?", serviceTypeId: "=?",
periodId: "=?" periodId: "=?"
......
...@@ -10,6 +10,10 @@ ...@@ -10,6 +10,10 @@
style="margin-top: 30px;"> style="margin-top: 30px;">
</div> </div>
</div> </div>
<!--<div class="page-footer">
<ack-pagination page-options="pagingOptions"
refresh-table="refreshConfigGrid()"></ack-pagination>
</div>-->
</div> </div>
</div> </div>
</div> </div>
......
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