EmployeeServiceImpl.java
4.19 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
package com.bsth.service.schedule.impl;
import com.bsth.entity.Personnel;
import com.bsth.service.schedule.EmployeeService;
import com.bsth.service.schedule.exception.ScheduleException;
import com.bsth.service.schedule.utils.DataToolsProperties;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.CollectionUtils;
import java.io.File;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.util.HashMap;
import java.util.Map;
/**
* Created by xu on 16/12/15.
*/
@EnableConfigurationProperties(DataToolsProperties.class)
@Service
public class EmployeeServiceImpl extends BServiceImpl<Personnel, Integer> implements EmployeeService {
/** 日志记录器 */
private static final Logger LOGGER = LoggerFactory.getLogger(EmployeeServiceImpl.class);
@Autowired
private DataToolsProperties dataToolsProperties;
@Override
public void importData(File file, Map<String, Object> params) throws ScheduleException {
try {
LOGGER.info("//---------------- 导入人员基础信息 start... ----------------//");
// 创建ktr转换所需参数
Map<String, Object> ktrParms = new HashMap<>();
File ktrFile = new File(this.getClass().getResource(
dataToolsProperties.getEmployeesDatainputktr()).toURI());
// 通用参数,转换文件路径,excel输入文件路径,错误输出文件路径
ktrParms.put("transpath", ktrFile.getAbsolutePath());
ktrParms.put("filepath", file.getAbsolutePath());
ktrParms.put("erroroutputdir", dataToolsProperties.getTransErrordir());
super.importData(file, ktrParms);
LOGGER.info("//---------------- 导入人员基础信息 success... ----------------//");
} catch (Exception exp) {
LOGGER.info("//---------------- 导入人员基础信息 failed... ----------------//");
StringWriter sw = new StringWriter();
exp.printStackTrace(new PrintWriter(sw));
LOGGER.info(sw.toString());
throw new ScheduleException(exp.getMessage());
}
}
@Override
public File exportData(Map<String, Object> params) throws ScheduleException {
try {
LOGGER.info("//---------------- 导出人员基础信息 start... ----------------//");
// 创建ktr转换所需参数
Map<String, Object> ktrParms = new HashMap<>();
File ktrFile = new File(this.getClass().getResource(
dataToolsProperties.getEmployeesDataoutputktr()).toURI());
// 通用参数,转换文件路径,excel输出文件名
ktrParms.put("transpath", ktrFile.getAbsolutePath());
ktrParms.put("filename", "人员基础信息_download-");
File file = super.exportData(ktrParms);
LOGGER.info("//---------------- 导出人员基础信息 success... ----------------//");
return file;
} catch (Exception exp) {
LOGGER.info("//---------------- 导出人员基础信息 failed... ----------------//");
StringWriter sw = new StringWriter();
exp.printStackTrace(new PrintWriter(sw));
LOGGER.info(sw.toString());
throw new ScheduleException(exp.getMessage());
}
}
@Override
@Transactional
public void validate_gh(Personnel personnel) throws ScheduleException {
// 查询条件
Map<String, Object> param = new HashMap<>();
if (personnel.getId() != null) {
param.put("id_ne", personnel.getId());
}
param.put("companyCode_eq", personnel.getCompanyCode());
param.put("jobCode_eq", personnel.getJobCode());
if (!CollectionUtils.isEmpty(list(param))) {
throw new ScheduleException("相同公司工号重复");
}
}
}