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
3ab39e95
Commit
3ab39e95
authored
Nov 14, 2018
by
eddie.woo
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
modify
parent
4310c448
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
232 additions
and
6 deletions
+232
-6
pom.xml
atms-api/pom.xml
+32
-0
AtmsExceptionHandler.java
...ava/pwc/taxtech/atms/controller/AtmsExceptionHandler.java
+11
-2
DataImportController.java
...ava/pwc/taxtech/atms/controller/DataImportController.java
+15
-3
LgGlBalanceService.java
...ava/pwc/taxtech/atms/service/impl/LgGlBalanceService.java
+36
-0
DataInitTest.java
...i/src/test/java/pwc/taxtech/atms/common/DataInitTest.java
+121
-0
preview-trial-balance.ctrl.js
...trols/preview-trial-balance/preview-trial-balance.ctrl.js
+8
-1
preview-trial-balance.html
...controls/preview-trial-balance/preview-trial-balance.html
+1
-0
vatImportService.js
...rc/main/webapp/app/common/vatservices/vatImportService.js
+8
-0
No files found.
atms-api/pom.xml
View file @
3ab39e95
...
...
@@ -381,6 +381,38 @@
<scope>
system
</scope>
<systemPath>
${basedir}/lib/soap-client-1.0.jar
</systemPath>
</dependency>
<!--CXF-->
<dependency>
<groupId>
org.apache.cxf
</groupId>
<artifactId>
cxf-core
</artifactId>
<version>
3.2.6
</version>
</dependency>
<dependency>
<groupId>
org.apache.cxf
</groupId>
<artifactId>
cxf-rt-wsdl
</artifactId>
<version>
3.2.6
</version>
</dependency>
<dependency>
<groupId>
org.apache.cxf
</groupId>
<artifactId>
cxf-rt-bindings-soap
</artifactId>
<version>
3.2.6
</version>
</dependency>
<dependency>
<groupId>
org.apache.cxf
</groupId>
<artifactId>
cxf-rt-databinding-jaxb
</artifactId>
<version>
3.2.6
</version>
</dependency>
<dependency>
<groupId>
org.apache.cxf
</groupId>
<artifactId>
cxf-rt-frontend-jaxws
</artifactId>
<version>
3.2.6
</version>
</dependency>
<dependency>
<groupId>
org.apache.cxf
</groupId>
<artifactId>
cxf-rt-transports-http
</artifactId>
<version>
3.2.6
</version>
</dependency>
<!--CXF END-->
</dependencies>
<profiles>
...
...
atms-api/src/main/java/pwc/taxtech/atms/controller/AtmsExceptionHandler.java
View file @
3ab39e95
...
...
@@ -50,12 +50,21 @@ public class AtmsExceptionHandler extends ResponseEntityExceptionHandler {
}
@ExceptionHandler
(
value
=
Throwable
.
class
)
public
ApiResultDto
handle
(
HttpServletResponse
response
)
{
return
ApiResultDto
.
fail
(
"error."
);
public
void
handle
(
Throwable
throwable
,
HttpServletResponse
response
)
{
throwable
.
printStackTrace
();
//noinspection Duplicates
try
{
response
.
setCharacterEncoding
(
"UTF-8"
);
response
.
setContentType
(
"application/json; charset=UTF-8"
);
response
.
getWriter
().
write
(
JSON
.
toJSONString
(
ApiResultDto
.
fail
(
throwable
.
getMessage
())));
}
catch
(
IOException
e
)
{
logger
.
error
(
"customHandle error."
,
e
);
}
}
@ExceptionHandler
(
value
=
ServiceException
.
class
)
public
void
customHandle
(
pwc
.
taxtech
.
atms
.
common
.
ServiceException
exception
,
HttpServletResponse
response
)
{
//noinspection Duplicates
try
{
response
.
setCharacterEncoding
(
"UTF-8"
);
response
.
setContentType
(
"application/json; charset=UTF-8"
);
...
...
atms-api/src/main/java/pwc/taxtech/atms/controller/DataImportController.java
View file @
3ab39e95
package
pwc
.
taxtech
.
atms
.
controller
;
import
com.alibaba.fastjson.JSON
;
import
org.springframework.web.bind.annotation.*
;
import
org.springframework.web.bind.annotation.PostMapping
;
import
org.springframework.web.bind.annotation.RequestBody
;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.RestController
;
import
pwc.taxtech.atms.dpo.PagingDto
;
import
pwc.taxtech.atms.dto.ApiResultDto
;
import
pwc.taxtech.atms.dto.PagingResultDto
;
import
pwc.taxtech.atms.dto.vatdto.TrialBalanceDto
;
import
pwc.taxtech.atms.dto.vatdto.TrialBalanceParam
;
import
pwc.taxtech.atms.service.impl.DataImportService
;
import
pwc.taxtech.atms.service.impl.LgGlBalanceService
;
import
javax.annotation.Resource
;
import
java.util.List
;
...
...
@@ -17,6 +21,8 @@ public class DataImportController extends BaseController {
@Resource
private
DataImportService
dataImportService
;
@Resource
private
LgGlBalanceService
lgGlBalanceService
;
@PostMapping
(
"GetBalanceDataForDisplay"
)
public
PagingResultDto
<
TrialBalanceDto
>
getBalanceDataForDisplay
(
@RequestBody
TrialBalanceParam
param
)
{
...
...
@@ -29,7 +35,13 @@ public class DataImportController extends BaseController {
resultDto
.
setPageInfo
(
pagingDto
);
resultDto
.
setList
(
list
);
resultDto
.
setCalculateData
(
dataImportService
.
calculateData
(
list
));
// 直接返回对象,jackson解析不全
return
resultDto
;
}
@PostMapping
(
"queryGlBalance"
)
public
ApiResultDto
queryGlBalance
(
@RequestBody
TrialBalanceParam
param
)
{
ApiResultDto
resultDto
=
new
ApiResultDto
();
lgGlBalanceService
.
queryGlBalance
(
param
.
getOrgId
(),
param
.
getFromPeriod
(),
param
.
getToPeriod
());
return
resultDto
;
}
}
atms-api/src/main/java/pwc/taxtech/atms/service/impl/LgGlBalanceService.java
View file @
3ab39e95
...
...
@@ -10,14 +10,18 @@ import org.apache.commons.lang3.StringUtils;
import
org.springframework.stereotype.Service
;
import
pwc.taxtech.atms.common.ServiceException
;
import
pwc.taxtech.atms.common.config.SystemConfig
;
import
pwc.taxtech.atms.constant.Constant
;
import
pwc.taxtech.atms.dao.EnterpriseAccountMapper
;
import
pwc.taxtech.atms.dao.EnterpriseAccountSetOrgMapper
;
import
pwc.taxtech.atms.dao.OrganizationMapper
;
import
pwc.taxtech.atms.entity.*
;
import
pwc.taxtech.atms.vat.dao.GlBalanceMapper
;
import
pwc.taxtech.atms.vat.entity.GlBalance
;
import
pwc.taxtech.atms.vat.entity.GlBalanceExample
;
import
javax.annotation.Resource
;
import
java.text.SimpleDateFormat
;
import
java.util.Calendar
;
import
java.util.List
;
import
java.util.stream.Collectors
;
...
...
@@ -31,6 +35,8 @@ public class LgGlBalanceService extends BaseService {
private
EnterpriseAccountSetOrgMapper
setOrgMapper
;
@Resource
private
GlBalanceMapper
glBalanceMapper
;
@Resource
private
OrganizationMapper
organizationMapper
;
/**
* 科目余额数据同步
...
...
@@ -82,4 +88,34 @@ public class LgGlBalanceService extends BaseService {
}
}
/**
* 科目余额数据同步
*
* @param orgId String
* @param period YYYY-MM
* @throws ServiceException ex
*/
public
void
queryGlBalance
(
String
orgId
,
String
period
)
throws
ServiceException
{
Organization
org
=
organizationMapper
.
selectByPrimaryKey
(
orgId
);
if
(
null
==
org
)
{
return
;
}
queryGlBalance
(
org
,
period
);
}
/**
* @param orgId String
* @param fromPeriod Integer
* @param toPeriod Integer
* @throws ServiceException ex
*/
public
void
queryGlBalance
(
String
orgId
,
Integer
fromPeriod
,
Integer
toPeriod
)
throws
ServiceException
{
Calendar
calendar
=
Calendar
.
getInstance
();
for
(
int
i
=
fromPeriod
;
i
<=
toPeriod
;
i
++)
{
calendar
.
set
(
Calendar
.
MONTH
,
i
-
1
);
SimpleDateFormat
dateFormat
=
new
SimpleDateFormat
(
Constant
.
DateFormat
.
YEAR_MONTH
);
queryGlBalance
(
orgId
,
dateFormat
.
format
(
calendar
.
getTime
()));
}
}
}
atms-api/src/test/java/pwc/taxtech/atms/common/DataInitTest.java
View file @
3ab39e95
...
...
@@ -2,16 +2,29 @@ package pwc.taxtech.atms.common;
import
org.apache.commons.io.FileUtils
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.poi.openxml4j.exceptions.InvalidFormatException
;
import
org.apache.poi.ss.usermodel.*
;
import
org.junit.Test
;
import
pwc.taxtech.atms.CommonIT
;
import
pwc.taxtech.atms.entity.StandardAccount
;
import
pwc.taxtech.atms.invoice.InputInvoiceDetailMapper
;
import
pwc.taxtech.atms.invoice.InputInvoiceMapper
;
import
pwc.taxtech.atms.vat.entity.InputInvoice
;
import
pwc.taxtech.atms.vat.entity.InputInvoiceDetail
;
import
pwc.taxtech.atms.vat.entity.InputInvoiceExample
;
import
javax.annotation.Resource
;
import
java.io.File
;
import
java.io.IOException
;
import
java.nio.charset.StandardCharsets
;
import
java.util.List
;
import
java.util.Optional
;
public
class
DataInitTest
extends
CommonIT
{
@Resource
private
InputInvoiceMapper
inputInvoiceMapper
;
@Resource
private
InputInvoiceDetailMapper
inputInvoiceDetailMapper
;
@Test
public
void
initStandardAccount
()
{
...
...
@@ -73,7 +86,115 @@ public class DataInitTest extends CommonIT {
}
}
@Test
public
void
initInput
()
throws
Exception
{
Workbook
workbook
=
WorkbookFactory
.
create
(
new
File
(
"C:\\Users\\Eddie Wu\\Desktop\\导入/导入模板_进项主表_绿能_201809.xls"
));
Sheet
sheet
=
workbook
.
getSheetAt
(
0
);
for
(
int
r
=
1
;
r
<=
sheet
.
getLastRowNum
();
r
++)
{
try
{
for
(
int
c
=
0
;
c
<=
sheet
.
getRow
(
r
).
getLastCellNum
();
c
++)
{
Cell
cell
=
sheet
.
getRow
(
r
).
getCell
(
c
);
if
(
null
!=
cell
)
{
cell
.
setCellType
(
CellType
.
STRING
);
}
}
InputInvoice
invoice
=
new
InputInvoice
();
invoice
.
setID
(
CommonUtils
.
getUUID
());
invoice
.
setFPDM
(
sheet
.
getRow
(
r
).
getCell
(
1
).
getStringCellValue
());
invoice
.
setFPHM
(
sheet
.
getRow
(
r
).
getCell
(
2
).
getStringCellValue
());
invoice
.
setKPRQ
(
sheet
.
getRow
(
r
).
getCell
(
3
).
getStringCellValue
());
invoice
.
setGFSH
(
sheet
.
getRow
(
r
).
getCell
(
4
).
getStringCellValue
());
invoice
.
setGFMC
(
sheet
.
getRow
(
r
).
getCell
(
5
).
getStringCellValue
());
invoice
.
setXFSH
(
sheet
.
getRow
(
r
).
getCell
(
8
).
getStringCellValue
());
invoice
.
setXFMC
(
sheet
.
getRow
(
r
).
getCell
(
9
).
getStringCellValue
());
invoice
.
setFPLX
(
sheet
.
getRow
(
r
).
getCell
(
13
).
getStringCellValue
());
invoice
.
setHJJE
(
sheet
.
getRow
(
r
).
getCell
(
16
).
getStringCellValue
());
invoice
.
setHJSE
(
sheet
.
getRow
(
r
).
getCell
(
17
).
getStringCellValue
());
invoice
.
setJSHJ
(
sheet
.
getRow
(
r
).
getCell
(
18
).
getStringCellValue
());
invoice
.
setFPZT
(
sheet
.
getRow
(
r
).
getCell
(
27
).
getStringCellValue
());
invoice
.
setCYZT
(
sheet
.
getRow
(
r
).
getCell
(
28
).
getStringCellValue
());
invoice
.
setRZZT
(
sheet
.
getRow
(
r
).
getCell
(
29
).
getStringCellValue
());
invoice
.
setRZSQ
(
sheet
.
getRow
(
r
).
getCell
(
30
).
getStringCellValue
());
invoice
.
setRZSJ
(
sheet
.
getRow
(
r
).
getCell
(
31
).
getStringCellValue
());
invoice
.
setRZJG
(
sheet
.
getRow
(
r
).
getCell
(
32
).
getStringCellValue
());
invoice
.
setCJSJ
(
sheet
.
getRow
(
r
).
getCell
(
34
).
getStringCellValue
());
invoice
.
setLRRQ
(
sheet
.
getRow
(
r
).
getCell
(
38
).
getStringCellValue
());
inputInvoiceMapper
.
insertSelective
(
invoice
);
}
catch
(
Exception
e
)
{
e
.
printStackTrace
();
}
}
System
.
out
.
println
(
"end"
);
}
@Test
public
void
initInputDetail
()
throws
Exception
{
Workbook
workbook
=
WorkbookFactory
.
create
(
new
File
(
"C:\\Users\\Eddie Wu\\Desktop\\导入/导入模板_进项明细_绿能_201809.xls"
));
Sheet
sheet
=
workbook
.
getSheetAt
(
0
);
for
(
int
r
=
1
;
r
<=
sheet
.
getLastRowNum
();
r
++)
{
try
{
for
(
int
c
=
0
;
c
<=
sheet
.
getRow
(
r
).
getLastCellNum
();
c
++)
{
Cell
cell
=
sheet
.
getRow
(
r
).
getCell
(
c
);
if
(
null
!=
cell
)
{
cell
.
setCellType
(
CellType
.
STRING
);
}
}
InputInvoiceDetail
detail
=
new
InputInvoiceDetail
();
detail
.
setID
(
CommonUtils
.
getUUID
());
detail
.
setFPDM
(
sheet
.
getRow
(
r
).
getCell
(
1
).
getStringCellValue
());
detail
.
setFPHM
(
sheet
.
getRow
(
r
).
getCell
(
2
).
getStringCellValue
());
detail
.
setSPMC
(
sheet
.
getRow
(
r
).
getCell
(
3
).
getStringCellValue
());
detail
.
setDW
(
sheet
.
getRow
(
r
).
getCell
(
5
).
getStringCellValue
());
detail
.
setDJ
(
sheet
.
getRow
(
r
).
getCell
(
6
).
getStringCellValue
());
detail
.
setSPSL
(
sheet
.
getRow
(
r
).
getCell
(
7
).
getStringCellValue
());
detail
.
setJE
(
sheet
.
getRow
(
r
).
getCell
(
8
).
getStringCellValue
());
detail
.
setSLV
(
String
.
valueOf
(
Math
.
round
(
Double
.
valueOf
(
sheet
.
getRow
(
r
).
getCell
(
9
).
getStringCellValue
()))));
detail
.
setSE
(
sheet
.
getRow
(
r
).
getCell
(
10
).
getStringCellValue
());
// InputInvoiceExample example = new InputInvoiceExample();
// example.createCriteria().andFPDMEqualTo(detail.getFPDM()).andFPHMEqualTo(detail.getFPHM());
// Optional<InputInvoice> invoiceOptional = inputInvoiceMapper.selectByExample(example).stream().findFirst();
// if (!invoiceOptional.isPresent()) {
// continue;
// }
// detail.setFPID();
inputInvoiceDetailMapper
.
insertSelective
(
detail
);
}
catch
(
Exception
e
)
{
e
.
printStackTrace
();
}
}
System
.
out
.
println
(
"end"
);
}
public
static
void
main
(
String
[]
args
)
{
System
.
out
.
println
(
CommonUtils
.
getUUID
());
try
{
Workbook
workbook
=
WorkbookFactory
.
create
(
new
File
(
"C:\\Users\\Eddie Wu\\Desktop\\导入/导入模板_进项明细_乐叶_201807.xls"
));
Sheet
sheet
=
workbook
.
getSheetAt
(
0
);
for
(
int
r
=
1
;
r
<=
sheet
.
getLastRowNum
();
r
++)
{
for
(
int
c
=
0
;
c
<=
sheet
.
getRow
(
r
).
getLastCellNum
();
c
++)
{
Cell
cell
=
sheet
.
getRow
(
r
).
getCell
(
c
);
if
(
null
!=
cell
)
{
cell
.
setCellType
(
CellType
.
STRING
);
}
}
InputInvoiceDetail
detail
=
new
InputInvoiceDetail
();
detail
.
setID
(
CommonUtils
.
getUUID
());
detail
.
setFPDM
(
sheet
.
getRow
(
r
).
getCell
(
1
).
getStringCellValue
());
detail
.
setFPHM
(
sheet
.
getRow
(
r
).
getCell
(
2
).
getStringCellValue
());
detail
.
setSPMC
(
sheet
.
getRow
(
r
).
getCell
(
3
).
getStringCellValue
());
detail
.
setDW
(
sheet
.
getRow
(
r
).
getCell
(
5
).
getStringCellValue
());
detail
.
setDJ
(
sheet
.
getRow
(
r
).
getCell
(
6
).
getStringCellValue
());
detail
.
setSPSL
(
sheet
.
getRow
(
r
).
getCell
(
7
).
getStringCellValue
());
detail
.
setJE
(
sheet
.
getRow
(
r
).
getCell
(
8
).
getStringCellValue
());
detail
.
setSLV
(
String
.
valueOf
(
Math
.
round
(
Double
.
valueOf
(
sheet
.
getRow
(
r
).
getCell
(
9
).
getStringCellValue
()))));
detail
.
setSE
(
sheet
.
getRow
(
r
).
getCell
(
10
).
getStringCellValue
());
}
sheet
.
getFirstRowNum
();
}
catch
(
IOException
e
)
{
e
.
printStackTrace
();
}
catch
(
InvalidFormatException
e
)
{
e
.
printStackTrace
();
}
}
}
atms-web/src/main/webapp/app/common/controls/preview-trial-balance/preview-trial-balance.ctrl.js
View file @
3ab39e95
...
...
@@ -124,7 +124,14 @@
$scope
.
isToPrint
=
true
;
$scope
.
getDataFromDatabase
(
$scope
.
currentCategory
.
selected
.
id
,
$scope
.
filterData
.
periodFrom
,
$scope
.
filterData
.
periodTo
,
$scope
.
filterDataCriteria
,
true
);
}
};
$scope
.
queryGlBalance
=
function
()
{
vatImportService
.
queryGlBalance
(
$scope
.
filterData
.
periodFrom
,
$scope
.
filterData
.
periodTo
,
vatSessionService
.
project
.
organizationID
)
.
success
(
function
(
res
)
{
});
};
// function to get data from Backend
$scope
.
getDataFromDatabase
=
function
(
category
,
from
,
to
,
criteria
,
isExportOnly
)
{
...
...
atms-web/src/main/webapp/app/common/controls/preview-trial-balance/preview-trial-balance.html
View file @
3ab39e95
...
...
@@ -36,6 +36,7 @@
<!--<button id="btnDataFilter" class="hidden" ng-click="doDataFilter('')">Open Filter</button>
<button id="btnResetDataFilter" class="hidden" ng-click="doDataFilterReset()">Reset Filter</button>-->
<span
class=
"cursorPointer margin-right10"
ng-click=
"doExport('GL','xlsx')"
><i
class=
"fa fa-file-excel-o"
aria-hidden=
"true"
></i>
<span
translate=
"ExportBtn"
></span></span>
<span
class=
"cursorPointer margin-right10"
ng-click=
"queryGlBalance()"
><i
class=
"fa fa-file-excel-o"
aria-hidden=
"true"
></i>
<span>
数据同步
</span></span>
</div>
</div>
...
...
atms-web/src/main/webapp/app/common/vatservices/vatImportService.js
View file @
3ab39e95
...
...
@@ -249,6 +249,14 @@
// return $http.get('/DataImport/GetBalanceDataForDisplay?category=' + category + '&fromPeriod=' + fromPeriod + '&toPeriod=' + toPeriod + '&criteria=' + criteria, apiConfig.createVat());
},
queryGlBalance
:
function
(
fromPeriod
,
toPeriod
,
orgId
)
{
return
$http
.
post
(
'/DataImport/queryGlBalance'
,
{
fromPeriod
:
fromPeriod
,
toPeriod
:
toPeriod
,
orgId
:
orgId
},
apiConfig
.
createVat
());
},
updateACustomPrice
:
function
(
customId
,
invoiceAmount
)
{
return
$http
.
get
(
'/CustomsInvoice/UpdateACustomPrice?customId='
+
customId
+
'&invoiceAmount='
+
invoiceAmount
,
apiConfig
.
createVat
());
},
...
...
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