Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
T
traffic-front
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wangxiaoming
traffic-front
Commits
961dacb1
Commit
961dacb1
authored
May 31, 2018
by
frank.xa.zhang
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'dev' into dev_frank
parents
b6a1b65e
f92cb007
Show whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
601 additions
and
2 deletions
+601
-2
CommonUtils.java
...pi/src/main/java/pwc/taxtech/atms/common/CommonUtils.java
+19
-0
POIUtil.java
atms-api/src/main/java/pwc/taxtech/atms/common/POIUtil.java
+106
-0
FTPClientPool.java
.../main/java/pwc/taxtech/atms/common/ftp/FTPClientPool.java
+4
-0
TemplateMessage.java
...java/pwc/taxtech/atms/common/message/TemplateMessage.java
+11
-0
TemplateGroupController.java
.../pwc/taxtech/atms/controller/TemplateGroupController.java
+67
-0
CellTemplateConfigMapper.java
...n/java/pwc/taxtech/atms/dao/CellTemplateConfigMapper.java
+3
-0
CellTemplateMapper.java
...rc/main/java/pwc/taxtech/atms/dao/CellTemplateMapper.java
+3
-0
TemplateDao.java
...i/src/main/java/pwc/taxtech/atms/dao/dao/TemplateDao.java
+30
-0
TemplateGroupDao.java
.../main/java/pwc/taxtech/atms/dao/dao/TemplateGroupDao.java
+23
-0
FileSystemService.java
...main/java/pwc/taxtech/atms/service/FileSystemService.java
+25
-0
TemplateGroupService.java
...n/java/pwc/taxtech/atms/service/TemplateGroupService.java
+9
-0
FTPFileSystemServiceImpl.java
...c/taxtech/atms/service/impl/FTPFileSystemServiceImpl.java
+28
-0
TemplateGroupServiceImpl.java
...c/taxtech/atms/service/impl/TemplateGroupServiceImpl.java
+235
-2
CellTemplateConfigMapper.xml
...sources/pwc/taxtech/atms/dao/CellTemplateConfigMapper.xml
+21
-0
CellTemplateMapper.xml
...ain/resources/pwc/taxtech/atms/dao/CellTemplateMapper.xml
+17
-0
No files found.
atms-api/src/main/java/pwc/taxtech/atms/common/CommonUtils.java
View file @
961dacb1
...
@@ -15,6 +15,7 @@ import org.springframework.core.io.ClassPathResource;
...
@@ -15,6 +15,7 @@ import org.springframework.core.io.ClassPathResource;
import
pwc.taxtech.atms.dto.epaccount.EnterpriseAccountSetOrgDto
;
import
pwc.taxtech.atms.dto.epaccount.EnterpriseAccountSetOrgDto
;
public
class
CommonUtils
{
public
class
CommonUtils
{
public
static
final
int
BATCH_NUM
=
500
;
public
static
String
getUUID
()
{
public
static
String
getUUID
()
{
return
UUID
.
randomUUID
().
toString
().
toUpperCase
();
return
UUID
.
randomUUID
().
toString
().
toUpperCase
();
...
@@ -136,4 +137,22 @@ public class CommonUtils {
...
@@ -136,4 +137,22 @@ public class CommonUtils {
}
}
return
text
;
return
text
;
}
}
public
static
<
T
>
List
<
List
<
T
>>
subListWithLen
(
List
<
T
>
source
,
int
len
)
{
if
(
source
==
null
||
source
.
size
()
==
0
||
len
<
1
)
{
return
null
;
}
List
<
List
<
T
>>
result
=
new
ArrayList
<>();
int
count
=
(
source
.
size
()
+
len
-
1
)
/
len
;
for
(
int
i
=
0
;
i
<
count
;
i
++)
{
List
<
T
>
value
;
if
((
i
+
1
)
*
len
<
source
.
size
())
{
value
=
source
.
subList
(
i
*
len
,
(
i
+
1
)
*
len
);
}
else
{
value
=
source
.
subList
(
i
*
len
,
source
.
size
());
}
result
.
add
(
value
);
}
return
result
;
}
}
}
atms-api/src/main/java/pwc/taxtech/atms/common/POIUtil.java
0 → 100644
View file @
961dacb1
package
pwc
.
taxtech
.
atms
.
common
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.poi.hssf.usermodel.HSSFWorkbook
;
import
org.apache.poi.ss.usermodel.Cell
;
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.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
java.util.Optional
;
public
class
POIUtil
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
POIUtil
.
class
);
public
static
final
String
XLSX
=
".xlsx"
;
public
static
final
String
XLS
=
".xls"
;
public
static
Optional
<
Workbook
>
cloneNewSheet
(
Sheet
sheet
,
String
fileName
)
{
Workbook
workbook
;
try
{
if
(
StringUtils
.
endsWith
(
fileName
,
XLSX
))
{
workbook
=
new
XSSFWorkbook
();
}
else
if
(
StringUtils
.
endsWith
(
fileName
,
XLS
))
{
workbook
=
new
HSSFWorkbook
();
}
else
{
return
Optional
.
empty
();
}
Sheet
tmpSheet
=
workbook
.
createSheet
(
sheet
.
getSheetName
());
cloneSheet
(
sheet
,
tmpSheet
);
return
Optional
.
of
(
workbook
);
}
catch
(
Exception
e
)
{
logger
.
error
(
"cloneNewSheet error."
,
e
);
}
return
Optional
.
empty
();
}
public
static
void
cloneSheet
(
Sheet
sheet
,
Sheet
targetSheet
)
{
for
(
int
r
=
sheet
.
getFirstRowNum
();
r
<=
sheet
.
getLastRowNum
();
r
++)
{
Row
row
=
sheet
.
getRow
(
r
);
Row
targetRow
=
targetSheet
.
createRow
(
r
);
for
(
int
c
=
row
.
getFirstCellNum
();
c
<=
row
.
getLastCellNum
();
c
++)
{
Cell
cell
=
row
.
getCell
(
c
);
if
(
null
==
cell
){
continue
;
}
Cell
targetCell
=
targetRow
.
createCell
(
c
);
targetCell
.
setCellType
(
cell
.
getCellTypeEnum
());
switch
(
cell
.
getCellTypeEnum
())
{
case
STRING:
targetCell
.
setCellValue
(
cell
.
getStringCellValue
());
break
;
case
NUMERIC:
targetCell
.
setCellValue
(
cell
.
getNumericCellValue
());
break
;
case
BOOLEAN:
targetCell
.
setCellValue
(
cell
.
getBooleanCellValue
());
break
;
case
FORMULA:
targetCell
.
setCellFormula
(
cell
.
getCellFormula
());
break
;
// case ERROR:
//// case BLANK:
//// case _NONE:
default
:
break
;
}
if
(
null
!=
cell
.
getCellComment
())
{
targetCell
.
setCellComment
(
cell
.
getCellComment
());
}
if
(
null
!=
cell
.
getCellStyle
())
{
targetCell
.
getCellStyle
().
cloneStyleFrom
(
cell
.
getCellStyle
());
}
if
(
null
!=
cell
.
getHyperlink
())
{
targetCell
.
setHyperlink
(
cell
.
getHyperlink
());
}
}
}
}
public
static
String
getCellFormulaString
(
Cell
cell
)
{
switch
(
cell
.
getCellTypeEnum
())
{
case
STRING:
case
FORMULA:
case
BLANK:
return
cell
.
getStringCellValue
();
case
NUMERIC:
return
String
.
valueOf
(
cell
.
getNumericCellValue
());
case
BOOLEAN:
return
String
.
valueOf
(
cell
.
getBooleanCellValue
());
default
:
return
StringUtils
.
EMPTY
;
}
}
public
static
Optional
<
String
>
getFileSuffix
(
String
fileName
)
{
if
(
StringUtils
.
endsWith
(
fileName
,
XLSX
))
{
return
Optional
.
of
(
XLSX
);
}
else
if
(
StringUtils
.
endsWith
(
fileName
,
XLS
))
{
return
Optional
.
of
(
XLS
);
}
else
{
return
Optional
.
empty
();
}
}
}
atms-api/src/main/java/pwc/taxtech/atms/common/ftp/FTPClientPool.java
View file @
961dacb1
...
@@ -17,6 +17,7 @@ public class FTPClientPool {
...
@@ -17,6 +17,7 @@ public class FTPClientPool {
private
GenericObjectPoolConfig
config
;
private
GenericObjectPoolConfig
config
;
private
GenericObjectPool
<
FTPClient
>
pool
;
private
GenericObjectPool
<
FTPClient
>
pool
;
private
String
ftpRootPath
;
private
String
ftpRootPath
;
private
static
final
String
SYMBOL
=
"/"
;
@Value
(
"${ftp.host}"
)
@Value
(
"${ftp.host}"
)
private
String
ftpHost
;
private
String
ftpHost
;
...
@@ -58,6 +59,9 @@ public class FTPClientPool {
...
@@ -58,6 +59,9 @@ public class FTPClientPool {
}
else
{
}
else
{
upPath
=
filePath
;
upPath
=
filePath
;
}
}
if
(!
StringUtils
.
endsWith
(
upPath
,
SYMBOL
))
{
upPath
=
upPath
+
SYMBOL
;
}
FTPClient
client
=
getClient
();
FTPClient
client
=
getClient
();
if
(!
isExist
(
upPath
,
client
))
{
if
(!
isExist
(
upPath
,
client
))
{
mkDir
(
upPath
,
client
);
mkDir
(
upPath
,
client
);
...
...
atms-api/src/main/java/pwc/taxtech/atms/common/message/TemplateMessage.java
0 → 100644
View file @
961dacb1
package
pwc
.
taxtech
.
atms
.
common
.
message
;
public
class
TemplateMessage
{
public
static
final
String
TemplateGroupIDNotMatch
=
"TemplateGroupIDNotMatch"
;
public
static
final
String
SameCodeTemplateRepeat
=
"SameCodeTemplateRepeat"
;
public
static
final
String
SameNameTemplateRepeat
=
"SameNameTemplateRepeat"
;
public
static
final
String
TemplateGroupNameExist
=
"TemplateGroupNameExist"
;
public
static
final
String
SystemTypeCannotDelete
=
"SystemTypeCannotDelete"
;
public
static
final
String
OrganizationUsedTemplateGroup
=
"OrganizationUsedTemplateGroup"
;
}
atms-api/src/main/java/pwc/taxtech/atms/controller/TemplateGroupController.java
View file @
961dacb1
package
pwc
.
taxtech
.
atms
.
controller
;
package
pwc
.
taxtech
.
atms
.
controller
;
import
com.alibaba.fastjson.JSON
;
import
io.swagger.annotations.ApiOperation
;
import
io.swagger.annotations.ApiOperation
;
import
org.apache.commons.collections.CollectionUtils
;
import
org.slf4j.Logger
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
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
org.springframework.web.multipart.MultipartFile
;
import
pwc.taxtech.atms.common.ServiceException
;
import
pwc.taxtech.atms.common.ftp.FTPClientPool
;
import
pwc.taxtech.atms.common.ftp.FTPClientPool
;
import
pwc.taxtech.atms.common.message.ErrorMessage
;
import
pwc.taxtech.atms.dto.OperationResultDto
;
import
pwc.taxtech.atms.dto.OperationResultDto
;
import
pwc.taxtech.atms.dto.TemplateGroupDto
;
import
pwc.taxtech.atms.dto.TemplateGroupDto
;
import
pwc.taxtech.atms.service.TemplateGroupService
;
import
pwc.taxtech.atms.service.TemplateGroupService
;
...
@@ -63,4 +68,66 @@ public class TemplateGroupController {
...
@@ -63,4 +68,66 @@ public class TemplateGroupController {
}
}
return
result
;
return
result
;
}
}
@ResponseBody
@ApiOperation
(
value
=
"获取Sheet名称"
)
@RequestMapping
(
value
=
"getSheetNameList"
,
method
=
RequestMethod
.
POST
)
public
OperationResultDto
getSheetNameList
(
@RequestParam
MultipartFile
file
,
@RequestParam
String
filename
,
@RequestParam
String
tempFileName
)
{
try
{
if
(
null
==
file
)
{
return
OperationResultDto
.
error
(
ErrorMessage
.
NoFile
);
}
return
OperationResultDto
.
success
(
templateGroupService
.
getSheetNameList
(
file
));
}
catch
(
Exception
e
)
{
logger
.
error
(
"getSheetNameList error."
,
e
);
}
return
OperationResultDto
.
error
();
}
@ResponseBody
@ApiOperation
(
value
=
"导入模板"
)
@RequestMapping
(
value
=
"importTemplateGroupExcelFile"
,
method
=
RequestMethod
.
POST
)
public
OperationResultDto
importTemplateGroupExcelFile
(
@RequestParam
MultipartFile
file
,
@RequestParam
String
filename
,
@RequestParam
String
tempFileName
,
@RequestParam
String
jsonModel
)
{
try
{
if
(
null
==
file
)
{
return
OperationResultDto
.
error
(
ErrorMessage
.
NoFile
);
}
TemplateGroupDto
templateGroupDto
=
JSON
.
parseObject
(
jsonModel
,
TemplateGroupDto
.
class
);
if
(
CollectionUtils
.
isEmpty
(
templateGroupDto
.
getSheetNameList
()))
{
return
OperationResultDto
.
error
(
ErrorMessage
.
NoSelectSheet
);
}
templateGroupService
.
importTemplateGroupExcelFile
(
file
,
templateGroupDto
);
return
OperationResultDto
.
success
();
}
catch
(
ServiceException
e
)
{
return
OperationResultDto
.
error
(
e
.
getMessage
());
}
catch
(
Exception
e
)
{
logger
.
error
(
"importTemplateGroupExcelFile error."
,
e
);
}
return
OperationResultDto
.
error
(
ErrorMessage
.
SystemError
);
}
@ResponseBody
@ApiOperation
(
value
=
"导入报表"
)
@RequestMapping
(
value
=
"importTemplateExcelFile"
,
method
=
RequestMethod
.
POST
)
public
OperationResultDto
importTemplateExcelFile
(
@RequestParam
MultipartFile
file
,
@RequestParam
String
templateGroupID
,
@RequestParam
String
sheetList
,
@RequestParam
String
tempFileName
,
@RequestParam
String
reportType
,
@RequestParam
String
filename
)
{
try
{
templateGroupService
.
importTemplateExcelFile
(
file
,
templateGroupID
,
reportType
,
sheetList
);
return
OperationResultDto
.
success
();
}
catch
(
ServiceException
e
)
{
return
OperationResultDto
.
error
(
e
.
getMessage
());
}
catch
(
Exception
e
)
{
logger
.
error
(
"importTemplateExcelFile error."
,
e
);
}
return
OperationResultDto
.
error
(
ErrorMessage
.
SystemError
);
}
}
}
atms-api/src/main/java/pwc/taxtech/atms/dao/CellTemplateConfigMapper.java
View file @
961dacb1
...
@@ -109,4 +109,6 @@ public interface CellTemplateConfigMapper extends MyMapper {
...
@@ -109,4 +109,6 @@ public interface CellTemplateConfigMapper extends MyMapper {
List
<
CellTemplateConfig
>
getCellTemplateConfigByTemplateID
(
@Param
(
"templateID"
)
String
templateID
);
List
<
CellTemplateConfig
>
getCellTemplateConfigByTemplateID
(
@Param
(
"templateID"
)
String
templateID
);
int
deleteCellTemplateConfigByCellTemplate
(
@Param
(
"templateDbID"
)
String
templateDbID
);
int
deleteCellTemplateConfigByCellTemplate
(
@Param
(
"templateDbID"
)
String
templateDbID
);
void
batchInsert
(
List
<
CellTemplateConfig
>
list
);
}
}
\ No newline at end of file
atms-api/src/main/java/pwc/taxtech/atms/dao/CellTemplateMapper.java
View file @
961dacb1
...
@@ -106,5 +106,7 @@ public interface CellTemplateMapper extends MyMapper {
...
@@ -106,5 +106,7 @@ public interface CellTemplateMapper extends MyMapper {
*/
*/
int
updateByPrimaryKey
(
CellTemplate
record
);
int
updateByPrimaryKey
(
CellTemplate
record
);
void
batchInsert
(
List
<
CellTemplate
>
list
);
}
}
\ No newline at end of file
atms-api/src/main/java/pwc/taxtech/atms/dao/dao/TemplateDao.java
0 → 100644
View file @
961dacb1
package
pwc
.
taxtech
.
atms
.
dao
.
dao
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
pwc.taxtech.atms.dao.TemplateMapper
;
import
pwc.taxtech.atms.entitiy.Template
;
import
pwc.taxtech.atms.entitiy.TemplateExample
;
import
java.util.List
;
@Service
public
class
TemplateDao
{
@Autowired
private
TemplateMapper
mapper
;
public
List
<
Template
>
getByName
(
String
name
)
{
TemplateExample
example
=
new
TemplateExample
();
TemplateExample
.
Criteria
criteria
=
example
.
createCriteria
();
criteria
.
andNameEqualTo
(
name
);
return
mapper
.
selectByExample
(
example
);
}
public
List
<
Template
>
getByCode
(
String
code
)
{
TemplateExample
example
=
new
TemplateExample
();
TemplateExample
.
Criteria
criteria
=
example
.
createCriteria
();
criteria
.
andCodeEqualTo
(
code
);
return
mapper
.
selectByExample
(
example
);
}
}
atms-api/src/main/java/pwc/taxtech/atms/dao/dao/TemplateGroupDao.java
0 → 100644
View file @
961dacb1
package
pwc
.
taxtech
.
atms
.
dao
.
dao
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
pwc.taxtech.atms.dao.TemplateGroupMapper
;
import
pwc.taxtech.atms.entitiy.TemplateGroup
;
import
pwc.taxtech.atms.entitiy.TemplateGroupExample
;
import
java.util.List
;
@Service
public
class
TemplateGroupDao
{
@Autowired
private
TemplateGroupMapper
mapper
;
public
List
<
TemplateGroup
>
getByGroupName
(
String
name
)
{
TemplateGroupExample
example
=
new
TemplateGroupExample
();
TemplateGroupExample
.
Criteria
criteria
=
example
.
createCriteria
();
criteria
.
andNameEqualTo
(
name
);
return
mapper
.
selectByExample
(
example
);
}
}
atms-api/src/main/java/pwc/taxtech/atms/service/FileSystemService.java
0 → 100644
View file @
961dacb1
package
pwc
.
taxtech
.
atms
.
service
;
import
java.io.InputStream
;
public
interface
FileSystemService
{
/**
* 上传用户报表模板
*
* @param fileName 文件名
* @param inputStream InputStream
* @return 文件路径
* @throws Exception ex
*/
String
uploadUserTemplate
(
String
fileName
,
InputStream
inputStream
)
throws
Exception
;
/**
* 下载用户报表模板
*
* @param filePath 文件路径
* @return InputStream
* @throws Exception ex
*/
InputStream
downloadUserTemplate
(
String
filePath
)
throws
Exception
;
}
atms-api/src/main/java/pwc/taxtech/atms/service/TemplateGroupService.java
View file @
961dacb1
package
pwc
.
taxtech
.
atms
.
service
;
package
pwc
.
taxtech
.
atms
.
service
;
import
pwc.taxtech.atms.dto.OperationResultDto
;
import
pwc.taxtech.atms.dto.OperationResultDto
;
import
org.springframework.web.multipart.MultipartFile
;
import
pwc.taxtech.atms.common.ServiceException
;
import
pwc.taxtech.atms.dto.TemplateGroupDto
;
import
pwc.taxtech.atms.dto.TemplateGroupDto
;
import
java.util.List
;
import
java.util.List
;
...
@@ -13,4 +15,11 @@ public interface TemplateGroupService {
...
@@ -13,4 +15,11 @@ public interface TemplateGroupService {
OperationResultDto
<
Object
>
updateTemplateGroupName
(
TemplateGroupDto
templateGroupDto
);
OperationResultDto
<
Object
>
updateTemplateGroupName
(
TemplateGroupDto
templateGroupDto
);
OperationResultDto
<
Object
>
deleteTemplateGroup
(
TemplateGroupDto
templateGroupDto
);
OperationResultDto
<
Object
>
deleteTemplateGroup
(
TemplateGroupDto
templateGroupDto
);
List
<
String
>
getSheetNameList
(
MultipartFile
file
);
void
importTemplateGroupExcelFile
(
MultipartFile
file
,
TemplateGroupDto
templateGroupDto
)
throws
ServiceException
;
void
importTemplateExcelFile
(
MultipartFile
file
,
String
templateGroupID
,
String
reportType
,
String
sheetList
)
throws
ServiceException
;
}
}
atms-api/src/main/java/pwc/taxtech/atms/service/impl/FTPFileSystemServiceImpl.java
0 → 100644
View file @
961dacb1
package
pwc
.
taxtech
.
atms
.
service
.
impl
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
pwc.taxtech.atms.common.ftp.FTPClientPool
;
import
pwc.taxtech.atms.service.FileSystemService
;
import
java.io.InputStream
;
@Service
public
class
FTPFileSystemServiceImpl
implements
FileSystemService
{
private
static
final
String
USER_TEMPLATE_PATH
=
"pwc/userTemplate/"
;
@Autowired
private
FTPClientPool
ftpClientPool
;
@Override
public
String
uploadUserTemplate
(
String
fileName
,
InputStream
inputStream
)
throws
Exception
{
ftpClientPool
.
upload
(
USER_TEMPLATE_PATH
,
fileName
,
inputStream
);
return
USER_TEMPLATE_PATH
+
fileName
;
}
@Override
public
InputStream
downloadUserTemplate
(
String
filePath
)
throws
Exception
{
return
ftpClientPool
.
download
(
filePath
);
}
}
atms-api/src/main/java/pwc/taxtech/atms/service/impl/TemplateGroupServiceImpl.java
View file @
961dacb1
package
pwc
.
taxtech
.
atms
.
service
.
impl
;
package
pwc
.
taxtech
.
atms
.
service
.
impl
;
import
com.alibaba.fastjson.JSON
;
import
com.google.common.collect.Lists
;
import
org.apache.commons.collections.CollectionUtils
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.poi.ss.usermodel.*
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
import
org.springframework.transaction.annotation.Propagation
;
import
org.springframework.transaction.annotation.Propagation
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.web.multipart.MultipartFile
;
import
pwc.taxtech.atms.common.CommonUtils
;
import
pwc.taxtech.atms.common.CommonUtils
;
import
pwc.taxtech.atms.common.POIUtil
;
import
pwc.taxtech.atms.common.ServiceException
;
import
pwc.taxtech.atms.common.message.ErrorMessage
;
import
pwc.taxtech.atms.common.message.TemplateMessage
;
import
pwc.taxtech.atms.constant.enums.TemplateGroupType
;
import
pwc.taxtech.atms.constant.enums.TemplateGroupType
;
import
pwc.taxtech.atms.dao.CellTemplateConfigMapper
;
import
pwc.taxtech.atms.dao.CellTemplateMapper
;
import
pwc.taxtech.atms.dao.TemplateGroupMapper
;
import
pwc.taxtech.atms.dao.TemplateMapper
;
import
pwc.taxtech.atms.dao.dao.TemplateGroupDao
;
import
pwc.taxtech.atms.dto.OperationResultDto
;
import
pwc.taxtech.atms.dto.OperationResultDto
;
import
pwc.taxtech.atms.dto.TemplateGroupDto
;
import
pwc.taxtech.atms.dto.TemplateGroupDto
;
import
pwc.taxtech.atms.entitiy.*
;
import
pwc.taxtech.atms.entitiy.*
;
import
pwc.taxtech.atms.service.FileSystemService
;
import
pwc.taxtech.atms.service.TemplateGroupService
;
import
pwc.taxtech.atms.service.TemplateGroupService
;
import
java.util.ArrayList
;
import
java.io.ByteArrayInputStream
;
import
java.util.List
;
import
java.io.ByteArrayOutputStream
;
import
java.io.InputStream
;
import
java.util.*
;
import
java.util.stream.Collectors
;
import
java.util.stream.Collectors
;
@Service
@Service
public
class
TemplateGroupServiceImpl
extends
AbstractService
implements
TemplateGroupService
{
public
class
TemplateGroupServiceImpl
extends
AbstractService
implements
TemplateGroupService
{
@Autowired
private
FileSystemService
fileSystemService
;
@Autowired
private
TemplateGroupDao
templateGroupDao
;
@Autowired
private
TemplateGroupMapper
templateGroupMapper
;
@Autowired
private
TemplateMapper
templateMapper
;
@Autowired
private
CellTemplateMapper
cellTemplateMapper
;
@Autowired
private
CellTemplateConfigMapper
cellTemplateConfigMapper
;
@Override
@Override
public
List
<
TemplateGroupDto
>
get
()
{
public
List
<
TemplateGroupDto
>
get
()
{
...
@@ -121,4 +152,206 @@ public class TemplateGroupServiceImpl extends AbstractService implements Templat
...
@@ -121,4 +152,206 @@ public class TemplateGroupServiceImpl extends AbstractService implements Templat
static
final
String
ORGANIZATION_USED_TEMPLATE_GROUP
=
"OrganizationUsedTemplateGroup"
;
static
final
String
ORGANIZATION_USED_TEMPLATE_GROUP
=
"OrganizationUsedTemplateGroup"
;
}
}
@Override
public
List
<
String
>
getSheetNameList
(
MultipartFile
file
)
{
try
{
Workbook
workbook
=
WorkbookFactory
.
create
(
file
.
getInputStream
());
List
<
String
>
nameList
=
Lists
.
newArrayList
();
for
(
int
i
=
0
;
i
<
workbook
.
getNumberOfSheets
();
i
++)
{
nameList
.
add
(
workbook
.
getSheetName
(
i
));
}
return
nameList
;
}
catch
(
Exception
e
)
{
logger
.
error
(
"getSheetNameList error."
,
e
);
}
return
Collections
.
emptyList
();
}
@Transactional
@Override
public
void
importTemplateGroupExcelFile
(
MultipartFile
file
,
TemplateGroupDto
templateGroupDto
)
throws
ServiceException
{
List
<
String
>
sheetNameList
=
templateGroupDto
.
getSheetNameList
();
if
(
CollectionUtils
.
isEmpty
(
sheetNameList
))
{
throw
new
ServiceException
(
ErrorMessage
.
NoSelectSheet
);
}
try
{
List
<
TemplateGroup
>
groupList
=
templateGroupDao
.
getByGroupName
(
templateGroupDto
.
getName
());
if
(
CollectionUtils
.
isNotEmpty
(
groupList
))
{
throw
new
ServiceException
(
TemplateMessage
.
TemplateGroupNameExist
);
}
InputStream
inputStream
=
file
.
getInputStream
();
String
fileName
=
file
.
getOriginalFilename
();
Workbook
workbook
=
WorkbookFactory
.
create
(
inputStream
);
List
<
Template
>
filePathList
=
Lists
.
newArrayList
();
String
templateGroupId
=
CommonUtils
.
getUUID
();
Date
now
=
new
Date
();
TemplateGroup
templateGroup
=
new
TemplateGroup
();
CommonUtils
.
copyProperties
(
templateGroupDto
,
templateGroup
);
templateGroup
.
setID
(
templateGroupId
);
templateGroup
.
setGroupType
(
1
);
//todo 整理枚举
templateGroup
.
setCopyFrom
(
StringUtils
.
EMPTY
);
templateGroup
.
setIsSystemType
(
false
);
templateGroup
.
setUpdateTime
(
now
);
templateGroupMapper
.
insertSelective
(
templateGroup
);
for
(
int
i
=
0
;
i
<=
workbook
.
getNumberOfSheets
();
i
++)
{
String
sheetName
=
workbook
.
getSheetName
(
i
);
String
newName
=
sheetName
+
CommonUtils
.
getUUID
()
+
POIUtil
.
getFileSuffix
(
fileName
).
get
();
Sheet
sheet
=
workbook
.
getSheetAt
(
i
);
Optional
<
Workbook
>
optional
=
POIUtil
.
cloneNewSheet
(
sheet
,
fileName
);
if
(!
optional
.
isPresent
())
{
throw
new
ServiceException
(
ErrorMessage
.
SystemError
);
}
ByteArrayOutputStream
bos
=
new
ByteArrayOutputStream
();
optional
.
get
().
write
(
bos
);
String
tmpPath
=
fileSystemService
.
uploadUserTemplate
(
newName
,
new
ByteArrayInputStream
(
bos
.
toByteArray
()));
String
[]
arr
=
sheetName
.
split
(
"_"
);
String
name
=
arr
.
length
>=
2
?
arr
[
1
]
:
arr
[
0
];
Template
template
=
new
Template
();
template
.
setCode
(
arr
[
0
]);
template
.
setCreateTime
(
now
);
template
.
setID
(
CommonUtils
.
getUUID
());
template
.
setIsActiveAssociation
(
true
);
template
.
setIsSystemType
(
false
);
template
.
setName
(
name
);
template
.
setOrderIndex
(
i
+
1
);
template
.
setPath
(
tmpPath
);
// template.setReportType(tmpPath);
template
.
setTemplateGroupID
(
templateGroupId
);
filePathList
.
add
(
template
);
templateMapper
.
insertSelective
(
template
);
List
<
CellTemplate
>
cellTemplateList
=
Lists
.
newArrayList
();
List
<
CellTemplateConfig
>
cellTemplateConfigList
=
Lists
.
newArrayList
();
for
(
int
r
=
sheet
.
getFirstRowNum
();
i
<=
sheet
.
getLastRowNum
();
i
++)
{
Row
row
=
sheet
.
getRow
(
r
);
for
(
int
c
=
row
.
getFirstCellNum
();
c
<=
row
.
getLastCellNum
();
c
++)
{
Cell
cell
=
row
.
getCell
(
c
);
if
(
cell
==
null
)
{
continue
;
//todo cell == null 如何处理
}
CellTemplate
cellTemplate
=
new
CellTemplate
();
cellTemplate
.
setColumnIndex
(
c
);
cellTemplate
.
setCreateTime
(
now
);
cellTemplate
.
setUpdateTime
(
now
);
cellTemplate
.
setRowIndex
(
r
);
cellTemplate
.
setReportTemplateID
(
template
.
getID
());
cellTemplate
.
setID
(
CommonUtils
.
getUUID
());
if
(
cell
.
getCellComment
()
!=
null
)
{
cellTemplate
.
setComment
(
cell
.
getCellComment
().
getString
().
getString
());
}
cellTemplate
.
setIsReadOnly
(
cell
.
getCellStyle
().
getLocked
()
?
1
:
0
);
cellTemplateList
.
add
(
cellTemplate
);
CellTemplateConfig
config
=
new
CellTemplateConfig
();
config
.
setID
(
CommonUtils
.
getUUID
());
config
.
setCellTemplateID
(
cellTemplate
.
getID
());
config
.
setReportTemplateID
(
template
.
getID
());
config
.
setDataSourceType
(
1
);
//todo 枚举
config
.
setFormula
(
POIUtil
.
getCellFormulaString
(
cell
));
// config.setFormulaDataSource(); //todo KV相关
config
.
setUpdateTime
(
now
);
config
.
setUpdater
(
authUserHelper
.
getCurrentUserID
());
cellTemplateConfigList
.
add
(
config
);
}
}
List
<
List
<
CellTemplate
>>
tmpList
=
CommonUtils
.
subListWithLen
(
cellTemplateList
,
CommonUtils
.
BATCH_NUM
);
tmpList
.
stream
().
forEach
(
list
->
cellTemplateMapper
.
batchInsert
(
list
));
List
<
List
<
CellTemplateConfig
>>
tmpConfigList
=
CommonUtils
.
subListWithLen
(
cellTemplateConfigList
,
CommonUtils
.
BATCH_NUM
);
tmpConfigList
.
stream
().
forEach
(
list
->
cellTemplateConfigMapper
.
batchInsert
(
list
));
}
}
catch
(
Exception
e
)
{
logger
.
error
(
"importTemplateGroupExcelFile error."
,
e
);
throw
new
ServiceException
(
ErrorMessage
.
SystemError
);
}
}
@Override
public
void
importTemplateExcelFile
(
MultipartFile
file
,
String
templateGroupID
,
String
reportType
,
String
sheetList
)
throws
ServiceException
{
if
(
null
==
file
)
{
throw
new
ServiceException
(
ErrorMessage
.
NoFile
);
}
try
{
if
(
StringUtils
.
isBlank
(
sheetList
))
{
throw
new
ServiceException
(
ErrorMessage
.
NoSelectSheet
);
}
List
<
String
>
sheetNameList
=
JSON
.
parseArray
(
sheetList
,
String
.
class
);
if
(
CollectionUtils
.
isEmpty
(
sheetNameList
))
{
throw
new
ServiceException
(
ErrorMessage
.
NoSelectSheet
);
}
InputStream
inputStream
=
file
.
getInputStream
();
String
fileName
=
file
.
getOriginalFilename
();
Workbook
workbook
=
WorkbookFactory
.
create
(
inputStream
);
List
<
Template
>
filePathList
=
Lists
.
newArrayList
();
Date
now
=
new
Date
();
for
(
int
i
=
0
;
i
<=
workbook
.
getNumberOfSheets
();
i
++)
{
String
sheetName
=
workbook
.
getSheetName
(
i
);
String
newName
=
sheetName
+
CommonUtils
.
getUUID
()
+
POIUtil
.
getFileSuffix
(
fileName
).
get
();
Sheet
sheet
=
workbook
.
getSheetAt
(
i
);
Optional
<
Workbook
>
optional
=
POIUtil
.
cloneNewSheet
(
sheet
,
fileName
);
if
(!
optional
.
isPresent
())
{
throw
new
ServiceException
(
ErrorMessage
.
SystemError
);
}
ByteArrayOutputStream
bos
=
new
ByteArrayOutputStream
();
optional
.
get
().
write
(
bos
);
String
tmpPath
=
fileSystemService
.
uploadUserTemplate
(
newName
,
new
ByteArrayInputStream
(
bos
.
toByteArray
()));
String
[]
arr
=
sheetName
.
split
(
"_"
);
String
name
=
arr
.
length
>=
2
?
arr
[
1
]
:
arr
[
0
];
Template
template
=
new
Template
();
template
.
setCode
(
arr
[
0
]);
template
.
setCreateTime
(
now
);
template
.
setID
(
CommonUtils
.
getUUID
());
template
.
setIsActiveAssociation
(
true
);
template
.
setIsSystemType
(
false
);
template
.
setName
(
name
);
template
.
setOrderIndex
(
i
+
1
);
template
.
setPath
(
tmpPath
);
template
.
setReportType
(
StringUtils
.
isBlank
(
reportType
)
?
null
:
Integer
.
valueOf
(
reportType
));
template
.
setTemplateGroupID
(
templateGroupID
);
filePathList
.
add
(
template
);
templateMapper
.
insertSelective
(
template
);
List
<
CellTemplate
>
cellTemplateList
=
Lists
.
newArrayList
();
List
<
CellTemplateConfig
>
cellTemplateConfigList
=
Lists
.
newArrayList
();
for
(
int
r
=
sheet
.
getFirstRowNum
();
i
<=
sheet
.
getLastRowNum
();
i
++)
{
Row
row
=
sheet
.
getRow
(
r
);
for
(
int
c
=
row
.
getFirstCellNum
();
c
<=
row
.
getLastCellNum
();
c
++)
{
Cell
cell
=
row
.
getCell
(
c
);
if
(
cell
==
null
)
{
continue
;
//todo cell == null 如何处理
}
CellTemplate
cellTemplate
=
new
CellTemplate
();
cellTemplate
.
setColumnIndex
(
c
);
cellTemplate
.
setCreateTime
(
now
);
cellTemplate
.
setUpdateTime
(
now
);
cellTemplate
.
setRowIndex
(
r
);
cellTemplate
.
setReportTemplateID
(
template
.
getID
());
cellTemplate
.
setID
(
CommonUtils
.
getUUID
());
if
(
cell
.
getCellComment
()
!=
null
)
{
cellTemplate
.
setComment
(
cell
.
getCellComment
().
getString
().
getString
());
}
cellTemplate
.
setIsReadOnly
(
cell
.
getCellStyle
().
getLocked
()
?
1
:
0
);
cellTemplateList
.
add
(
cellTemplate
);
CellTemplateConfig
config
=
new
CellTemplateConfig
();
config
.
setID
(
CommonUtils
.
getUUID
());
config
.
setCellTemplateID
(
cellTemplate
.
getID
());
config
.
setReportTemplateID
(
template
.
getID
());
config
.
setDataSourceType
(
1
);
//todo 枚举
config
.
setFormula
(
POIUtil
.
getCellFormulaString
(
cell
));
// config.setFormulaDataSource(); //todo KV相关
config
.
setUpdateTime
(
now
);
config
.
setUpdater
(
authUserHelper
.
getCurrentUserID
());
cellTemplateConfigList
.
add
(
config
);
}
}
List
<
List
<
CellTemplate
>>
tmpList
=
CommonUtils
.
subListWithLen
(
cellTemplateList
,
CommonUtils
.
BATCH_NUM
);
tmpList
.
stream
().
forEach
(
list
->
cellTemplateMapper
.
batchInsert
(
list
));
List
<
List
<
CellTemplateConfig
>>
tmpConfigList
=
CommonUtils
.
subListWithLen
(
cellTemplateConfigList
,
CommonUtils
.
BATCH_NUM
);
tmpConfigList
.
stream
().
forEach
(
list
->
cellTemplateConfigMapper
.
batchInsert
(
list
));
}
}
catch
(
Exception
e
)
{
logger
.
error
(
"importTemplateExcelFile error."
,
e
);
throw
new
ServiceException
(
ErrorMessage
.
SystemError
);
}
}
}
}
atms-api/src/main/resources/pwc/taxtech/atms/dao/CellTemplateConfigMapper.xml
View file @
961dacb1
...
@@ -544,4 +544,24 @@ WHERE
...
@@ -544,4 +544,24 @@ WHERE
c.ReportTemplateID = #{templateDbID,jdbcType=VARCHAR}
c.ReportTemplateID = #{templateDbID,jdbcType=VARCHAR}
) x)
) x)
</delete>
</delete>
<insert
id=
"batchInsert"
parameterType=
"pwc.taxtech.atms.entitiy.CellTemplateConfig"
>
insert into CellTemplateConfig (ID, CellTemplateID, ReportTemplateID,
DataSourceType, Formula, FormulaDescription,
AccountCodes, InvoiceType, TaxRate,
InvoiceAmountType, ModelIDs, Creator,
CreateTime, Updater, UpdateTime,
InvoiceCategory, FormulaDataSource, Validation,
ValidationDescription, VoucherKeyword)
values
<foreach
collection =
"list"
item=
"item"
separator =
","
>
(#{item.ID,jdbcType=VARCHAR}, #{item.cellTemplateID,jdbcType=VARCHAR}, #{item.reportTemplateID,jdbcType=VARCHAR},
#{item.dataSourceType,jdbcType=INTEGER}, #{item.formula,jdbcType=VARCHAR}, #{item.formulaDescription,jdbcType=VARCHAR},
#{item.accountCodes,jdbcType=VARCHAR}, #{item.invoiceType,jdbcType=INTEGER}, #{item.taxRate,jdbcType=VARCHAR},
#{item.invoiceAmountType,jdbcType=INTEGER}, #{item.modelIDs,jdbcType=VARCHAR}, #{item.creator,jdbcType=VARCHAR},
#{item.createTime,jdbcType=TIMESTAMP}, #{item.updater,jdbcType=VARCHAR}, #{item.updateTime,jdbcType=TIMESTAMP},
#{item.invoiceCategory,jdbcType=VARCHAR}, #{item.formulaDataSource,jdbcType=VARCHAR}, #{item.validation,jdbcType=VARCHAR},
#{item.validationDescription,jdbcType=VARCHAR}, #{item.voucherKeyword,jdbcType=VARCHAR})
</foreach>
</insert>
</mapper>
</mapper>
\ No newline at end of file
atms-api/src/main/resources/pwc/taxtech/atms/dao/CellTemplateMapper.xml
View file @
961dacb1
...
@@ -398,4 +398,20 @@
...
@@ -398,4 +398,20 @@
order by ${orderByClause}
order by ${orderByClause}
</if>
</if>
</select>
</select>
<insert
id=
"batchInsert"
>
insert into CellTemplate (ID, ReportTemplateID, RowIndex,
RowName, ColumnIndex, ColumnName,
Comment, CreateTime, UpdateTime,
CopyFromID, DataType, IsReadOnly
)
values
<foreach
collection =
"list"
item=
"item"
separator =
","
>
(#{item.ID,jdbcType=VARCHAR}, #{item.reportTemplateID,jdbcType=VARCHAR}, #{item.rowIndex,jdbcType=INTEGER},
#{item.rowName,jdbcType=VARCHAR}, #{item.columnIndex,jdbcType=INTEGER}, #{item.columnName,jdbcType=VARCHAR},
#{item.comment,jdbcType=VARCHAR}, #{item.createTime,jdbcType=TIMESTAMP}, #{item.updateTime,jdbcType=TIMESTAMP},
#{item.copyFromID,jdbcType=VARCHAR}, #{item.dataType,jdbcType=INTEGER}, #{item.isReadOnly,jdbcType=INTEGER}
)
</foreach >
</insert>
</mapper>
</mapper>
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment