Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
A
amos-boot-zx-biz
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Jobs
Commits
Open sidebar
项目统一框架
一体化_户用光伏项目代码
amos-boot-zx-biz
Commits
c75d2e66
Commit
c75d2e66
authored
Aug 27, 2024
by
chenzhao
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
修改代码
parent
afb98290
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
63 additions
and
27 deletions
+63
-27
AcceptanceCheckDto.java
...oin/amos/boot/module/hygf/api/dto/AcceptanceCheckDto.java
+18
-0
AcceptanceCheckMapper.java
...os/boot/module/hygf/api/mapper/AcceptanceCheckMapper.java
+4
-2
AcceptanceCheckAuditingMapper.xml
.../resources/mapper/mysql/AcceptanceCheckAuditingMapper.xml
+0
-0
AcceptanceCheckMapper.xml
...src/main/resources/mapper/mysql/AcceptanceCheckMapper.xml
+0
-0
BasicGridAuditingMapper.xml
...c/main/resources/mapper/mysql/BasicGridAuditingMapper.xml
+0
-0
BasicGridRecordMapper.xml
...src/main/resources/mapper/mysql/BasicGridRecordMapper.xml
+0
-0
AcceptanceCheckController.java
...module/hygf/biz/controller/AcceptanceCheckController.java
+10
-5
HygfRectificationOrderController.java
...hygf/biz/controller/HygfRectificationOrderController.java
+22
-11
AcceptanceCheckServiceImpl.java
...ule/hygf/biz/service/impl/AcceptanceCheckServiceImpl.java
+8
-8
WorkOrderServiceImpl.java
...ot/module/hygf/biz/service/impl/WorkOrderServiceImpl.java
+1
-1
No files found.
amos-boot-system-jxiop/amos-boot-module-hygf-api/src/main/java/com/yeejoin/amos/boot/module/hygf/api/dto/AcceptanceCheckDto.java
View file @
c75d2e66
...
@@ -54,6 +54,24 @@ public class AcceptanceCheckDto extends BaseDto {
...
@@ -54,6 +54,24 @@ public class AcceptanceCheckDto extends BaseDto {
private
String
acceptanceTime
;
private
String
acceptanceTime
;
//电站编号
private
String
peasantHouseholdNo
;
//户主姓名
private
String
ownersName
;
///项目地址
private
String
projectAddressName
;
//并网日期
private
Date
gridConnectionTime
;
private
String
regionalCompaniesName
;
private
String
serviceAgent
;
//并网登记id
private
Long
fonGridId
;
private
String
isAudit
;
private
String
isAudit
;
}
}
amos-boot-system-jxiop/amos-boot-module-hygf-api/src/main/java/com/yeejoin/amos/boot/module/hygf/api/mapper/AcceptanceCheckMapper.java
View file @
c75d2e66
package
com
.
yeejoin
.
amos
.
boot
.
module
.
hygf
.
api
.
mapper
;
package
com
.
yeejoin
.
amos
.
boot
.
module
.
hygf
.
api
.
mapper
;
import
com.yeejoin.amos.boot.module.hygf.api.config.UserEmpower
;
import
com.yeejoin.amos.boot.module.hygf.api.dto.AcceptanceCheckDto
;
import
com.yeejoin.amos.boot.module.hygf.api.dto.AcceptanceCheckDto
;
import
com.yeejoin.amos.boot.module.hygf.api.entity.AcceptanceCheck
;
import
com.yeejoin.amos.boot.module.hygf.api.entity.AcceptanceCheck
;
import
com.baomidou.mybatisplus.core.mapper.BaseMapper
;
import
com.baomidou.mybatisplus.core.mapper.BaseMapper
;
import
org.apache.ibatis.annotations.Param
;
import
java.util.List
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Map
;
...
@@ -14,6 +16,6 @@ import java.util.Map;
...
@@ -14,6 +16,6 @@ import java.util.Map;
* @date 2024-08-21
* @date 2024-08-21
*/
*/
public
interface
AcceptanceCheckMapper
extends
BaseMapper
<
AcceptanceCheck
>
{
public
interface
AcceptanceCheckMapper
extends
BaseMapper
<
AcceptanceCheck
>
{
@UserEmpower
(
field
={
"hph.regional_companies_code"
}
,
dealerField
={
"hph.developer_code"
,
"hph.regional_companies_code"
,
"hph.developer_user_id"
},
fieldConditions
={
"in"
,
"in"
,
"in"
}
,
relationship
=
"and"
)
List
<
AcceptanceCheckDto
>
selectPageList
(
Map
<
String
,
Object
>
map
);
List
<
AcceptanceCheckDto
>
selectPageList
(
@Param
(
"map"
)
Map
<
String
,
Object
>
map
);
}
}
amos-boot-system-jxiop/amos-boot-module-hygf-api/src/main/resources/mapper/AcceptanceCheckAuditingMapper.xml
→
amos-boot-system-jxiop/amos-boot-module-hygf-api/src/main/resources/mapper/
mysql/
AcceptanceCheckAuditingMapper.xml
View file @
c75d2e66
File moved
amos-boot-system-jxiop/amos-boot-module-hygf-api/src/main/resources/mapper/AcceptanceCheckMapper.xml
→
amos-boot-system-jxiop/amos-boot-module-hygf-api/src/main/resources/mapper/
mysql/
AcceptanceCheckMapper.xml
View file @
c75d2e66
File moved
amos-boot-system-jxiop/amos-boot-module-hygf-api/src/main/resources/mapper/BasicGridAuditingMapper.xml
→
amos-boot-system-jxiop/amos-boot-module-hygf-api/src/main/resources/mapper/
mysql/
BasicGridAuditingMapper.xml
View file @
c75d2e66
File moved
amos-boot-system-jxiop/amos-boot-module-hygf-api/src/main/resources/mapper/BasicGridRecordMapper.xml
→
amos-boot-system-jxiop/amos-boot-module-hygf-api/src/main/resources/mapper/
mysql/
BasicGridRecordMapper.xml
View file @
c75d2e66
File moved
amos-boot-system-jxiop/amos-boot-module-hygf-biz/src/main/java/com/yeejoin/amos/boot/module/hygf/biz/controller/AcceptanceCheckController.java
View file @
c75d2e66
...
@@ -3,6 +3,7 @@ package com.yeejoin.amos.boot.module.hygf.biz.controller;
...
@@ -3,6 +3,7 @@ package com.yeejoin.amos.boot.module.hygf.biz.controller;
import
com.yeejoin.amos.boot.biz.common.bo.ReginParams
;
import
com.yeejoin.amos.boot.biz.common.bo.ReginParams
;
import
com.yeejoin.amos.boot.module.hygf.api.config.UserLimits
;
import
com.yeejoin.amos.boot.module.hygf.api.config.UserLimits
;
import
com.yeejoin.amos.boot.module.hygf.api.dto.BasicGridRecordDto
;
import
com.yeejoin.amos.boot.module.hygf.api.dto.BasicGridRecordDto
;
import
com.yeejoin.amos.boot.module.hygf.api.entity.AcceptanceCheck
;
import
com.yeejoin.amos.boot.module.hygf.api.entity.HygfRectificationOrder
;
import
com.yeejoin.amos.boot.module.hygf.api.entity.HygfRectificationOrder
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.transaction.annotation.Transactional
;
...
@@ -61,11 +62,11 @@ public class AcceptanceCheckController extends BaseController {
...
@@ -61,11 +62,11 @@ public class AcceptanceCheckController extends BaseController {
* @return
* @return
*/
*/
@TycloudOperation
(
ApiLevel
=
UserType
.
AGENCY
)
@TycloudOperation
(
ApiLevel
=
UserType
.
AGENCY
)
@PostMapping
(
value
=
"/save"
)
@PostMapping
(
value
=
"/save
/commit
"
)
@ApiOperation
(
httpMethod
=
"POST"
,
value
=
"新增并网验收节点"
,
notes
=
"新增并网验收节点"
)
@ApiOperation
(
httpMethod
=
"POST"
,
value
=
"新增并网验收节点"
,
notes
=
"新增并网验收节点"
)
public
ResponseModel
<
AcceptanceCheck
Dto
>
save
(
@RequestBody
AcceptanceCheckDto
model
)
{
public
ResponseModel
<
AcceptanceCheck
>
save
(
@RequestBody
Map
<
String
,
Object
>
model
)
{
model
=
acceptanceCheckServiceImpl
.
createWithModel
(
model
);
return
ResponseHelper
.
buildResponse
(
model
);
return
ResponseHelper
.
buildResponse
(
acceptanceCheckServiceImpl
.
saveAndCommit
(
model
)
);
}
}
/**
/**
...
@@ -239,7 +240,11 @@ public class AcceptanceCheckController extends BaseController {
...
@@ -239,7 +240,11 @@ public class AcceptanceCheckController extends BaseController {
if
(
null
!=
e
.
getBasicGridNode
()
&&
e
.
getBasicGridNode
().
contains
(
g
)
&&
(
roleIds
.
contains
(
areaId
)
||
roleIds
.
contains
(
fawuId
)
||
roleIds
.
contains
(
zichanId
)||
roleIds
.
contains
(
tourongId
))){
if
(
null
!=
e
.
getBasicGridNode
()
&&
e
.
getBasicGridNode
().
contains
(
g
)
&&
(
roleIds
.
contains
(
areaId
)
||
roleIds
.
contains
(
fawuId
)
||
roleIds
.
contains
(
zichanId
)||
roleIds
.
contains
(
tourongId
))){
e
.
setIsAudit
(
"0"
);
e
.
setIsAudit
(
"0"
);
break
;
break
;
}
else
{
}
if
(
e
.
getBasicGridNode
().
equals
(
"jxsAdmin"
)
&&
roleIds
.
contains
(
delerAdminId
)){
e
.
setIsAudit
(
"0"
);
break
;
}
else
{
e
.
setIsAudit
(
"1"
);
e
.
setIsAudit
(
"1"
);
}
}
}
}
...
...
amos-boot-system-jxiop/amos-boot-module-hygf-biz/src/main/java/com/yeejoin/amos/boot/module/hygf/biz/controller/HygfRectificationOrderController.java
View file @
c75d2e66
...
@@ -50,6 +50,12 @@ public class HygfRectificationOrderController extends BaseController {
...
@@ -50,6 +50,12 @@ public class HygfRectificationOrderController extends BaseController {
Long
delerAdminId
;
Long
delerAdminId
;
@Value
(
"${admin.delerKaId.roleId}"
)
@Value
(
"${admin.delerKaId.roleId}"
)
Long
delerKfId
;
Long
delerKfId
;
@Value
(
"${admin.tourong.roleId}"
)
Long
tourongId
;
@Value
(
"${admin.fawu.roleId}"
)
Long
fawuId
;
@Value
(
"${admin.zichan.roleId}"
)
Long
zichanId
;
/**
/**
* 新增审核单
* 新增审核单
*
*
...
@@ -240,23 +246,28 @@ public class HygfRectificationOrderController extends BaseController {
...
@@ -240,23 +246,28 @@ public class HygfRectificationOrderController extends BaseController {
for
(
Long
aLong
:
reginParams
.
getUserModel
().
getOrgRoleSeqs
().
keySet
())
{
for
(
Long
aLong
:
reginParams
.
getUserModel
().
getOrgRoleSeqs
().
keySet
())
{
List
<
Long
>
longs
=
reginParams
.
getUserModel
().
getOrgRoleSeqs
().
get
(
aLong
);
List
<
Long
>
longs
=
reginParams
.
getUserModel
().
getOrgRoleSeqs
().
get
(
aLong
);
if
(
longs
.
contains
(
areaId
)
)
{
if
(
longs
.
contains
(
areaId
)
)
{
workOrderPowerStationNodes
.
add
(
"
bw
-area"
);
workOrderPowerStationNodes
.
add
(
"
ys
-area"
);
}
}
if
(
longs
.
contains
(
engineeri
ngId
)
)
{
if
(
longs
.
contains
(
touro
ngId
)
)
{
workOrderPowerStationNodes
.
add
(
"
bw
-engineering"
);
workOrderPowerStationNodes
.
add
(
"
ys
-engineering"
);
}
}
if
(
longs
.
contains
(
design
Id
)
)
{
if
(
longs
.
contains
(
fawu
Id
)
)
{
workOrderPowerStationNodes
.
add
(
"
bw
-design"
);
workOrderPowerStationNodes
.
add
(
"
ys
-design"
);
}
}
if
(
longs
.
contains
(
delerAdminId
)
)
{
if
(
longs
.
contains
(
delerAdminId
)
)
{
workOrderPowerStationNodes
.
add
(
"
bw
-design"
);
workOrderPowerStationNodes
.
add
(
"
ys
-design"
);
workOrderPowerStationNodes
.
add
(
"
bw
-engineering"
);
workOrderPowerStationNodes
.
add
(
"
ys
-engineering"
);
workOrderPowerStationNodes
.
add
(
"
bw
-area"
);
workOrderPowerStationNodes
.
add
(
"
ys
-area"
);
}
if
(
longs
.
contains
(
delerKfId
)
)
{
}
if
(
longs
.
contains
(
delerKfId
)
)
{
workOrderPowerStationNodes
.
add
(
"
bw
-design"
);
workOrderPowerStationNodes
.
add
(
"
ys
-design"
);
workOrderPowerStationNodes
.
add
(
"
bw
-engineering"
);
workOrderPowerStationNodes
.
add
(
"
ys
-engineering"
);
workOrderPowerStationNodes
.
add
(
"
bw
-area"
);
workOrderPowerStationNodes
.
add
(
"
ys
-area"
);
}
}
// if (longs.contains(delergcId) ) {
// workOrderPowerStationNodes.add("ys-design");
// workOrderPowerStationNodes.add("ys-engineering");
// workOrderPowerStationNodes.add("ys-area");
// }
}
}
Page
<
HygfRectificationOrder
>
page
=
hygfRectificationOrderServiceImpl
.
queryForHygfRectificationOrderPage
(
current
,
size
,
workOrderPowerStationNodes
,
peasantHouseholeId
);
Page
<
HygfRectificationOrder
>
page
=
hygfRectificationOrderServiceImpl
.
queryForHygfRectificationOrderPage
(
current
,
size
,
workOrderPowerStationNodes
,
peasantHouseholeId
);
...
...
amos-boot-system-jxiop/amos-boot-module-hygf-biz/src/main/java/com/yeejoin/amos/boot/module/hygf/biz/service/impl/AcceptanceCheckServiceImpl.java
View file @
c75d2e66
...
@@ -49,6 +49,8 @@ public class AcceptanceCheckServiceImpl extends BaseService<AcceptanceCheckDto,A
...
@@ -49,6 +49,8 @@ public class AcceptanceCheckServiceImpl extends BaseService<AcceptanceCheckDto,A
@Autowired
@Autowired
HygfRectificationOrderServiceImpl
rectificationOrderService
;
HygfRectificationOrderServiceImpl
rectificationOrderService
;
@Autowired
@Autowired
AcceptanceCheckMapper
acceptanceCheckMapper
;
@Autowired
PeasantHouseholdMapper
peasantHouseholdMapper
;
PeasantHouseholdMapper
peasantHouseholdMapper
;
...
@@ -72,7 +74,7 @@ public class AcceptanceCheckServiceImpl extends BaseService<AcceptanceCheckDto,A
...
@@ -72,7 +74,7 @@ public class AcceptanceCheckServiceImpl extends BaseService<AcceptanceCheckDto,A
map
.
put
(
"amosDealerId"
,
amosDealerId
);
map
.
put
(
"amosDealerId"
,
amosDealerId
);
map
.
put
(
"basicGridNodes"
,
basicGridNodes
);
map
.
put
(
"basicGridNodes"
,
basicGridNodes
);
map
.
put
(
"type"
,
type
);
map
.
put
(
"type"
,
type
);
List
<
AcceptanceCheckDto
>
list
=
this
.
getBaseMapper
()
.
selectPageList
(
map
);
List
<
AcceptanceCheckDto
>
list
=
acceptanceCheckMapper
.
selectPageList
(
map
);
PageInfo
<
AcceptanceCheckDto
>
page
=
new
PageInfo
(
list
);
PageInfo
<
AcceptanceCheckDto
>
page
=
new
PageInfo
(
list
);
Page
<
AcceptanceCheckDto
>
pageNew
=
new
Page
<>();
Page
<
AcceptanceCheckDto
>
pageNew
=
new
Page
<>();
pageNew
.
setCurrent
(
current
);
pageNew
.
setCurrent
(
current
);
...
@@ -98,17 +100,15 @@ public class AcceptanceCheckServiceImpl extends BaseService<AcceptanceCheckDto,A
...
@@ -98,17 +100,15 @@ public class AcceptanceCheckServiceImpl extends BaseService<AcceptanceCheckDto,A
public
synchronized
HygfOnGrid
saveAndCommit
(
HygfOnGrid
grid
,
String
userId
)
{
public
AcceptanceCheck
saveAndCommit
(
Map
<
String
,
Object
>
model
)
{
AcceptanceCheck
basicGridRecord
=
this
.
getBaseMapper
()
AcceptanceCheck
basicGridRecord
=
this
.
getBaseMapper
().
selectById
(
model
.
get
(
"sequenceNbr"
).
toString
());
.
selectOne
(
new
LambdaQueryWrapper
<
AcceptanceCheck
>()
.
eq
(
AcceptanceCheck:
:
getWorkOrderPowerStationId
,
grid
.
getWorkOrderPowerStationId
()));
LambdaUpdateWrapper
<
AcceptanceCheck
>
update
=
new
LambdaUpdateWrapper
<>();
LambdaUpdateWrapper
<
AcceptanceCheck
>
update
=
new
LambdaUpdateWrapper
<>();
update
.
set
(
AcceptanceCheck:
:
getAcceptanceCheckStatus
,
GridStatusEnum
.
JXSGLYDSH
.
getCode
());
update
.
set
(
AcceptanceCheck:
:
getAcceptanceCheckStatus
,
GridStatusEnum
.
JXSGLYDSH
.
getCode
());
update
.
set
(
AcceptanceCheck:
:
getBasicGridNode
,
"jxsAdmin"
);
update
.
set
(
AcceptanceCheck:
:
getBasicGridNode
,
"jxsAdmin"
);
if
(
grid
.
getType
()
!=
null
&&
"1"
.
equals
(
grid
.
getType
()))
{
if
(
model
.
get
(
"type"
)
!=
null
&&
"1"
.
equals
(
model
.
get
(
"type"
).
toString
()))
{
// 执行工作流
// 执行工作流
this
.
wofkflowExcute
(
basicGridRecord
.
getInstanceId
(),
"0"
,
"重新验收"
);
this
.
wofkflowExcute
(
basicGridRecord
.
getInstanceId
(),
"0"
,
"重新验收"
);
update
.
set
(
AcceptanceCheck:
:
getPowerStationAreaStatus
,
null
);
update
.
set
(
AcceptanceCheck:
:
getPowerStationAreaStatus
,
null
);
...
@@ -134,7 +134,7 @@ public class AcceptanceCheckServiceImpl extends BaseService<AcceptanceCheckDto,A
...
@@ -134,7 +134,7 @@ public class AcceptanceCheckServiceImpl extends BaseService<AcceptanceCheckDto,A
WorkflowResultDto
workflowResultDto
=
workflowResultDtos
.
get
(
0
);
WorkflowResultDto
workflowResultDto
=
workflowResultDtos
.
get
(
0
);
AcceptanceCheckAuditingDto
basicGridAuditingDto
=
new
AcceptanceCheckAuditingDto
();
AcceptanceCheckAuditingDto
basicGridAuditingDto
=
new
AcceptanceCheckAuditingDto
();
BeanUtils
.
copyProperties
(
workflowResultDto
,
basicGridAuditingDto
);
BeanUtils
.
copyProperties
(
workflowResultDto
,
basicGridAuditingDto
);
basicGridAuditingDto
.
setPeasantHouseholdId
(
gri
d
.
getPeasantHouseholdId
());
basicGridAuditingDto
.
setPeasantHouseholdId
(
basicGridRecor
d
.
getPeasantHouseholdId
());
basicGridAuditingDto
.
setPromoter
(
RequestContext
.
getExeUserId
());
basicGridAuditingDto
.
setPromoter
(
RequestContext
.
getExeUserId
());
acceptanceCheckAuditingService
.
createWithModel
(
basicGridAuditingDto
);
acceptanceCheckAuditingService
.
createWithModel
(
basicGridAuditingDto
);
update
.
set
(
AcceptanceCheck:
:
getInstanceId
,
basicGridAuditingDto
.
getInstanceId
());
update
.
set
(
AcceptanceCheck:
:
getInstanceId
,
basicGridAuditingDto
.
getInstanceId
());
...
@@ -161,7 +161,7 @@ public class AcceptanceCheckServiceImpl extends BaseService<AcceptanceCheckDto,A
...
@@ -161,7 +161,7 @@ public class AcceptanceCheckServiceImpl extends BaseService<AcceptanceCheckDto,A
this
.
update
(
null
,
update
);
this
.
update
(
null
,
update
);
//发起待办
//发起待办
// commonService.buildTaskModel(buildBWYSTaskModel(grid, basicGridAcceptance));
// commonService.buildTaskModel(buildBWYSTaskModel(grid, basicGridAcceptance));
return
gri
d
;
return
basicGridRecor
d
;
}
}
...
...
amos-boot-system-jxiop/amos-boot-module-hygf-biz/src/main/java/com/yeejoin/amos/boot/module/hygf/biz/service/impl/WorkOrderServiceImpl.java
View file @
c75d2e66
...
@@ -848,7 +848,7 @@ public class WorkOrderServiceImpl extends BaseService<WorkOrderDto, WorkOrder, W
...
@@ -848,7 +848,7 @@ public class WorkOrderServiceImpl extends BaseService<WorkOrderDto, WorkOrder, W
HygfOnGrid
hygfOnGrid
=
hygfOnGridMapper
.
selectOne
(
up4
);
HygfOnGrid
hygfOnGrid
=
hygfOnGridMapper
.
selectOne
(
up4
);
//增加整改单数据
//增加整改单数据
List
<
HygfRectificationOrder
>
hygfRectificationOrderList
=
rectificationOrderService
.
selectForListBySource
(
String
.
valueOf
(
peasantHousehold
.
getSequenceNbr
()),
RectificationOrderEnum
.
并网
.
get
Cod
e
());
List
<
HygfRectificationOrder
>
hygfRectificationOrderList
=
rectificationOrderService
.
selectForListBySource
(
String
.
valueOf
(
peasantHousehold
.
getSequenceNbr
()),
RectificationOrderEnum
.
并网
.
get
Nam
e
());
if
(
CollectionUtil
.
isNotEmpty
(
hygfRectificationOrderList
)){
if
(
CollectionUtil
.
isNotEmpty
(
hygfRectificationOrderList
)){
List
<
HygfRectificationOrder
>
areaOrders
=
hygfRectificationOrderList
.
stream
().
filter
(
e
->
e
.
getRectificationSource
().
equals
(
"area"
)).
collect
(
Collectors
.
toList
());
List
<
HygfRectificationOrder
>
areaOrders
=
hygfRectificationOrderList
.
stream
().
filter
(
e
->
e
.
getRectificationSource
().
equals
(
"area"
)).
collect
(
Collectors
.
toList
());
List
<
HygfRectificationOrder
>
engineeringOrders
=
hygfRectificationOrderList
.
stream
().
filter
(
e
->
e
.
getRectificationSource
().
equals
(
"engineering"
)).
collect
(
Collectors
.
toList
());
List
<
HygfRectificationOrder
>
engineeringOrders
=
hygfRectificationOrderList
.
stream
().
filter
(
e
->
e
.
getRectificationSource
().
equals
(
"engineering"
)).
collect
(
Collectors
.
toList
());
...
...
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