Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
I
ibzdst
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
1
议题
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
ibiz4jteam
ibzdst
提交
57c914ae
提交
57c914ae
编写于
9月 01, 2021
作者:
xuhui961310148
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
查看报表功能相关内容
上级
c89394ab
变更
6
隐藏空白字符变更
内嵌
并排
正在显示
6 个修改的文件
包含
613 行增加
和
1 行删除
+613
-1
package.json
app_web/package.json
+4
-0
dareport-bbzscustom-view.less
...is/dareport-bbzscustom-view/dareport-bbzscustom-view.less
+50
-0
dareport-bbzscustom-view.vue
...sis/dareport-bbzscustom-view/dareport-bbzscustom-view.vue
+392
-1
user-register.ts
app_web/src/user-register.ts
+2
-0
DACoreService.java
...ava/cn/ibizlab/core/extensions/service/DACoreService.java
+48
-0
DAGridCoreResource.java
...va/cn/ibizlab/api/rest/extensions/DAGridCoreResource.java
+117
-0
未找到文件。
app_web/package.json
浏览文件 @
57c914ae
...
...
@@ -12,6 +12,10 @@
"lint"
:
"vue-cli-service lint"
},
"dependencies"
:
{
"@riophae/vue-treeselect"
:
"0.0.38"
,
"ag-grid-community"
:
"^20.2.0"
,
"ag-grid-enterprise"
:
"^20.2.0"
,
"ag-grid-vue"
:
"^20.2.0"
,
"@fullcalendar/core"
:
"^4.4.0"
,
"@fullcalendar/daygrid"
:
"^4.4.0"
,
"@fullcalendar/interaction"
:
"^4.4.0"
,
...
...
app_web/src/pages/analysis/dareport-bbzscustom-view/dareport-bbzscustom-view.less
浏览文件 @
57c914ae
@import "../../../../node_modules/ag-grid-community/dist/styles/ag-grid.css";
@import "../../../../node_modules/ag-grid-community/dist/styles/ag-theme-balham.css";
@import "../../../../node_modules/ag-grid-community/dist/styles/ag-theme-dark.css";
@import "../../../../node_modules/ag-grid-community/dist/styles/ag-theme-fresh.css";
@import "../../../../node_modules/ag-grid-community/dist/styles/ag-theme-bootstrap.css";
@import "../../../../node_modules/ag-grid-community/dist/styles/ag-theme-blue.css";
@import "../../../../node_modules/ag-grid-community/dist/styles/ag-theme-balham-dark.css";
@import "../../../../node_modules/ag-grid-community/dist/styles/ag-theme-material.css";
.grid {
height: 100%;
overflow: auto;
.ag-theme-material {
height: calc(100% - 50px);
}
}
.ag-theme-material .ag-cell{
line-height: 40px;
}
.selectAndData {
display: flex;
padding: 10px 0;
> .vue-treeselect {
width: 14%;
> .vue-treeselect__control {
height: 40px;
}
}
> .el-select {
width: 9%;
}
}
label:hover{
white-space:normal;
}
.el-range-separator{
width: 30px !important;
}
.ivu-card-body{
overflow-y: hidden !important;
}
.dareport-bbzscustom-view{
position: relative;
}
...
...
app_web/src/pages/analysis/dareport-bbzscustom-view/dareport-bbzscustom-view.vue
浏览文件 @
57c914ae
<
template
>
<div
class=
"view-container decustomview dareport-bbzscustom-view"
>
<app-studioaction
:viewTitle=
"$t(model.srfCaption)"
viewName=
"dareportbbzscustomview"
></app-studioaction>
<card
class=
"view-card view-no-toolbar"
:disHover=
"true"
:padding=
"0"
:bordered=
"false"
>
<h6
style=
"text-align: center; padding: 5px"
>
{{
headname
}}
</h6>
<div
class=
"content-container"
>
<div
class=
"selectAndData"
>
<Treeselect
ref=
"orgid"
v-model=
"treeValue"
:options=
"treeOptions"
placeholder=
"请选择单位或区域"
></Treeselect>
<el-select
ref=
"cxfs"
v-model=
"computedSelectVal"
placeholder=
"请选择查询方式"
>
<template
v-if=
'options && options.length>0'
>
<template
v-for=
'(item) in options'
>
<el-option
:key=
"item.value"
:value=
"item.value"
:label=
"item.label"
></el-option>
</
template
>
</template>
</el-select>
<el-date-picker
ref=
"time"
v-model=
"dataValue"
:type=
'type'
range-separator=
'至'
:start-placeholder=
'startPlaceholder'
:end-placeholder=
'endPlaceholder'
></el-date-picker>
<div
class=
"toolbar"
style=
"margin-left: auto"
>
<el-button
@
click=
"getReportData"
>
搜索
</el-button>
</div>
</div>
<div
class=
"grid"
>
<ag-grid-vue
style=
"width: 100%; height: 95%"
class=
"ag-theme-balham"
:columnDefs=
"columnDefs"
:enableSorting=
"true"
:enableFilter=
"false"
:enableColResize=
"true"
:singleClickEdit=
"true"
:pagination=
"false"
rowSelection=
"multiple"
:localeText=
"localeText"
@
onGridReady=
"onGridReady"
@
onselectionChanged=
"selectionChanged"
@
onrowDoubleClicked=
"rowDoubleClicked"
:rowData=
"items"
></ag-grid-vue>
</div>
</div>
</card>
</div>
</template>
<
script
lang=
'tsx'
>
import
{
Component
}
from
'vue-property-decorator'
;
import
{
Component
,
Prop
,
Watch
,
Model
}
from
'vue-property-decorator'
;
import
DAReportBBZSCustomViewBase
from
'./dareport-bbzscustom-view-base.vue'
;
import
'ag-grid-enterprise'
;
import
Treeselect
from
'@riophae/vue-treeselect'
;
import
{
AgGridVue
}
from
"ag-grid-vue"
;
import
'@riophae/vue-treeselect/dist/vue-treeselect.css'
@
Component
({
components
:
{
'ag-grid-vue'
:
AgGridVue
,
'Treeselect'
:
Treeselect
},
beforeRouteEnter
:
(
to
:
any
,
from
:
any
,
next
:
any
)
=>
{
next
((
vm
:
any
)
=>
{
...
...
@@ -16,5 +67,345 @@ import DAReportBBZSCustomViewBase from './dareport-bbzscustom-view-base.vue';
})
export
default
class
DAReportBBZSCustomView
extends
DAReportBBZSCustomViewBase
{
/**
* 执行mounted后的逻辑
*
* @memberof DAReportBBZSCustomViewBase
*/
public
afterMounted
(){
const
_this
:
any
=
this
;
_this
.
engineInit
();
if
(
_this
.
loadModel
&&
_this
.
loadModel
instanceof
Function
)
{
_this
.
loadModel
();
}
_this
.
getXQCodelist
();
_this
.
getReportData
();
}
/**
* 表头
*/
public
columnDefs
:
any
[]
=
[];
public
headname
:
any
=
''
;
/**
* select绑定值
*/
@
Prop
()
public
selectValue
:
any
;
/**
* 计算绑定值
*/
set
computedSelectVal
(
val
:
any
)
{
this
.
selectValue
=
val
;
Object
.
assign
(
this
.
context
,{
dictcatalog
:
'CL_DST_REGION'
});
this
.
viewparams
}
get
computedSelectVal
()
{
return
this
.
selectValue
;
}
/**
* 选项值
*/
public
options
:
any
=
[
{
value
:
'year'
,
label
:
'按年查询'
,
},
{
value
:
'month'
,
label
:
'按月查询'
,
},
{
value
:
'day'
,
label
:
'按日查询'
,
}
];
/**
* data绑定值
*/
@
Model
(
'dataChange'
)
dataValue
:
any
;
/**
* 计算绑定值
*/
set
computedDataVal
(
val
:
any
)
{
this
.
$emit
(
'dataChange'
,
val
);
}
get
computedDataVal
()
{
return
this
.
dataValue
;
}
/**
* 选择类型
*/
public
type
:
any
;
public
startPlaceholder
:
any
;
public
endPlaceholder
:
any
;
/**
* 监听selectValue
* @param newVal
* @param oldVal
*/
@
Watch
(
'selectValue'
)
onselectionchange
(
newVal
:
any
,
oldVal
:
any
)
{
if
(
newVal
===
'year'
)
{
this
.
type
=
'year'
;
}
if
(
newVal
===
'month'
)
{
this
.
type
=
'monthrange'
;
this
.
startPlaceholder
=
'开始月份'
;
this
.
endPlaceholder
=
'结束月份'
;
}
if
(
newVal
===
'day'
)
{
this
.
type
=
'daterange'
;
this
.
startPlaceholder
=
'开始日期'
;
this
.
endPlaceholder
=
'结束日期'
;
}
}
/**
* 树项
*/
public
treeOptions
:
any
=
[];
/**
* 树值
* @param $event
*/
@
Model
(
'treeChange'
)
treeValue
:
any
;
/**
* 计算绑定值
*/
set
computedtreeVal
(
val
:
any
)
{
this
.
$emit
(
'treeChange'
,
val
);
}
get
computedtreeVal
()
{
return
this
.
treeValue
;
}
/**
* 获取辖区代码表
*/
public
getXQCodelist
(){
// 请求地址
const
post
:
Promise
<
any
>
=
this
.
$http
.
post
(
"/ibizutil/getCodelist"
,
{
cid
:
"CL_DST_REGION"
},
true
);
post
.
then
((
response
:
any
)
=>
{
if
(
response
&&
response
.
status
==
200
)
{
this
.
treeOptions
=
response
.
data
;
}
}).
catch
((
response
:
any
)
=>
{
if
(
!
response
||
!
response
.
status
||
!
response
.
data
)
{
this
.
$Notice
.
error
({
title
:
'错误'
,
desc
:
'系统异常'
});
return
;
}
const
{
data
:
_data
}
=
response
;
this
.
$Notice
.
error
({
title
:
_data
.
title
,
desc
:
_data
.
message
});
});
}
/**
* 请求数据
*/
public
getReportData
()
{
const
_this
:
any
=
this
;
// 置空表格数据
this
.
columnDefs
=
[];
// 机构
const
orgid
:
any
=
this
.
$refs
.
orgid
;
let
domin
=
orgid
.
value
;
// 类型
const
cxfs
:
any
=
this
.
$refs
.
cxfs
;
let
fs
=
cxfs
.
value
;
// 时间
const
time
:
any
=
this
.
$refs
.
time
;
let
timeAll
=
time
.
displayValue
;
let
startTime
:
any
;
let
endTime
:
any
;
if
(
fs
===
"year"
)
{
startTime
=
timeAll
+
'-01-01'
;
endTime
=
timeAll
+
'-12-31'
;
}
if
(
fs
===
"month"
)
{
startTime
=
timeAll
[
0
]
+
'-01'
;
endTime
=
timeAll
[
1
]
+
'-31'
;
}
if
(
fs
===
"day"
)
{
startTime
=
timeAll
[
0
];
endTime
=
timeAll
[
1
];
}
// 请求地址
debugger
const
post
:
Promise
<
any
>
=
this
.
$http
.
post
(
'/ibizutil/reportdatas'
,
{
id
:
JSON
.
parse
(
this
.
viewdata
).
srfparentkey
,
domin
:
domin
,
startTime
:
startTime
,
endTime
:
endTime
},
true
);
post
.
then
((
response
:
any
)
=>
{
if
(
response
&&
response
.
status
==
200
)
{
this
.
headname
=
response
.
data
.
reportname
;
let
reportname
=
{
headerName
:
response
.
data
.
reportname
,
field
:
''
,
//显示数据的字段名
filter
:
''
,
//过滤的类型
width
:
''
,
cellStyle
:
{
color
:
'red'
},
//单元格样式
children
:
response
.
data
.
resportdata
.
headData
,
//子项
};
this
.
items
=
response
.
data
.
resportdata
.
erportdata
[
0
];
this
.
columnDefs
.
push
(
reportname
);
}
}).
catch
((
response
:
any
)
=>
{
if
(
!
response
||
!
response
.
status
||
!
response
.
data
)
{
this
.
$Notice
.
error
({
title
:
'错误'
,
desc
:
'系统异常'
});
return
;
}
const
{
data
:
_data
}
=
response
;
this
.
$Notice
.
error
({
title
:
_data
.
title
,
desc
:
_data
.
message
});
});
}
/**
* 表格对象
*
* @memberof Main
*/
public
gridApi
:
any
;
/**
* 列对象
*
*
* @memberof Main
*/
public
columnApi
:
any
;
/**
* 数据
*
* @type {any[]}
* @memberof Main
*/
public
items
:
any
=
new
Array
();
/**
* 表格数据
*/
public
localeText
:
any
=
{
page
:
"页"
,
more
:
"更多"
,
to
:
"到"
,
of
:
"of"
,
next
:
"下一页"
,
last
:
"上一页"
,
first
:
"首页"
,
previous
:
"上一页"
,
loadingOoo
:
"加载中..."
,
selectAll
:
"查询全部"
,
searchOoo
:
"查询..."
,
blanks
:
"空白"
,
filterOoo
:
"过滤..."
,
applyFilter
:
"daApplyFilter..."
,
equals
:
"相等"
,
notEqual
:
"不相等"
,
lessThan
:
"小于"
,
greaterThan
:
"大于"
,
lessThanOrEqual
:
"小于等于"
,
greaterThanOrEqual
:
"大于等于"
,
inRange
:
"范围"
,
contains
:
"包含"
,
notContains
:
"不包含"
,
startsWith
:
"开始于"
,
endsWith
:
"结束于"
,
group
:
"组"
,
columns
:
"列"
,
filters
:
"筛选"
,
rowGroupColumns
:
"laPivot Cols"
,
rowGroupColumnsEmptyMessage
:
"la drag cols to group"
,
valueColumns
:
"laValue Cols"
,
pivotMode
:
"laPivot-Mode"
,
groups
:
"laGroups"
,
values
:
"值"
,
pivots
:
"laPivots"
,
valueColumnsEmptyMessage
:
"la drag cols to aggregate"
,
pivotColumnsEmptyMessage
:
"la drag here to pivot"
,
toolPanelButton
:
"la tool panel"
,
noRowsToShow
:
"数据为空"
,
pinColumn
:
"laPin Column"
,
valueAggregation
:
"laValue Agg"
,
autosizeThiscolumn
:
"laAutosize Diz"
,
autosizeAllColumns
:
"laAutsoie em All"
,
groupBy
:
"排序"
,
ungroupBy
:
"不排序"
,
resetColumns
:
"重置列"
,
expandAll
:
"展开全部"
,
collapseAll
:
"关闭"
,
toolPanel
:
"工具面板"
,
export
:
"导出"
,
csvExport
:
"导出为CSV格式文件"
,
excelExport
:
"导出到Excel"
,
pinLeft
:
"laPin <<"
,
pinRight
:
"laPin >>"
,
noPin
:
"laDontPin <>"
,
sum
:
"总数"
,
min
:
"最小值"
,
max
:
"最大值"
,
none
:
"无"
,
count
:
"总"
,
average
:
"平均值"
,
copy
:
"复制"
,
copyWithHeaders
:
"携带表头复制"
,
ctrlC
:
"ctrl + C"
,
paste
:
"粘贴"
,
ctrlV
:
"ctrl + V"
};
/**
* 表格加载完成
*
* @returns void
* @memberof Main
*/
public
onGridReady
(
$event
:
any
):
void
{
console
.
log
(
$event
);
this
.
gridApi
=
$event
.
api
;
this
.
columnApi
=
$event
.
columnApi
;
this
.
gridApi
.
sizeColumnsToFit
();
}
/**
* 行选中变化
*
* @returns void
* @memberof Main
*/
public
selectionChanged
(
$event
:
any
):
void
{
console
.
log
(
this
.
getSelections
());
}
/**
* 获取选中数据
*
* @returns {any[]}
* @memberof Main
*/
public
getSelections
():
any
[]
{
return
this
.
gridApi
.
getSelectedRows
();
}
/**
* 行双击
*
* @returns void
* @memberof Main
*/
public
rowDoubleClicked
(
$event
:
any
):
void
{
console
.
log
(
$event
.
data
);
}
}
</
script
>
\ No newline at end of file
app_web/src/user-register.ts
浏览文件 @
57c914ae
...
...
@@ -8,6 +8,8 @@ import AppFormJsonFieldSet from './components/app-form-json/app-form-json-field
import
AppFormJsonDim
from
'./components/app-form-json/app-form-json-dim.vue'
import
AppFormJsonMetric
from
'./components/app-form-json/app-form-json-metric.vue'
import
AppTreeselectRefreshview
from
'./components/app-treeselect-refreshview/app-treeselect-refreshview.vue'
import
{
LicenseManager
}
from
"ag-grid-enterprise"
;
LicenseManager
.
setLicenseKey
(
"Shanghai_iBizSys_Information_Technology_Co_Ltd__MultiApp_1Devs14_January_2020__MTU3ODk2MDAwMDAwMA==f9f9222e95025fd3f9069f3db4bdd40d"
);
import
'jquery/dist/jquery.min.js'
import
$
from
'jquery'
window
[
"$"
]
=
$
...
...
ibzdst-core/src/main/java/cn/ibizlab/core/extensions/service/DACoreService.java
浏览文件 @
57c914ae
...
...
@@ -892,6 +892,54 @@ public class DACoreService {
return
new
Timestamp
(
c
.
getTime
().
getTime
());
}
/**
* 时间转换
* @param strTimp
* @return
*/
public
static
Timestamp
getTimestamp
(
String
strTimp
)
{
Timestamp
timestamp
=
null
;
SimpleDateFormat
simpleDateFormat
=
new
SimpleDateFormat
(
"yyyy-MM-dd"
);
SimpleDateFormat
simpleDateFormatTwo
=
new
SimpleDateFormat
(
"yyyy-MM-dd HH:mm:ss"
);
SimpleDateFormat
simpleDateFormatCST
=
new
SimpleDateFormat
(
"EEE MMM dd HH:mm:ss zzz yyyy"
,
Locale
.
US
);
SimpleDateFormat
simpleDateFormatGMT
=
new
SimpleDateFormat
(
"EEE MMM ddHH:mm:ss 'GMT' yyyy"
,
Locale
.
US
);
SimpleDateFormat
simpleDateFormatUTC
=
new
SimpleDateFormat
(
"yyyy-MM-dd'T'HH:mm:ssZ"
);
try
{
if
(!
StringUtils
.
isEmpty
(
strTimp
)
&&
!(
"null"
.
equals
(
strTimp
)))
{
Date
date
=
null
;
if
(
strTimp
.
indexOf
(
"CST"
)
>=
0
)
{
date
=
simpleDateFormatCST
.
parse
(
strTimp
);
timestamp
=
new
Timestamp
(
date
.
getTime
());
return
timestamp
;
}
if
(
strTimp
.
indexOf
(
"GMT"
)
>=
0
)
{
date
=
simpleDateFormatGMT
.
parse
(
strTimp
);
timestamp
=
new
Timestamp
(
date
.
getTime
());
return
timestamp
;
}
if
(
strTimp
.
indexOf
(
"UT"
)
>=
0
)
{
date
=
simpleDateFormatUTC
.
parse
(
strTimp
);
timestamp
=
new
Timestamp
(
date
.
getTime
());
return
timestamp
;
}
if
(
strTimp
.
length
()
==
19
)
{
date
=
simpleDateFormatTwo
.
parse
(
strTimp
);
timestamp
=
new
Timestamp
(
date
.
getTime
());
return
timestamp
;
}
if
(
StringUtils
.
countOccurrencesOf
(
"now"
,
strTimp
)
!=
0
)
{
//strTimp等于now表示获取当前时间
date
=
new
Date
();
}
else
{
date
=
simpleDateFormat
.
parse
(
strTimp
);
}
timestamp
=
new
Timestamp
(
date
.
getTime
());
}
}
catch
(
Exception
e
)
{
e
.
printStackTrace
();
}
return
timestamp
;
}
public
Timestamp
getLastYear
(
Timestamp
time
)
{
Date
date
=
new
Date
(
time
.
getTime
());
...
...
ibzdst-provider/ibzdst-provider-api/src/main/java/cn/ibizlab/api/rest/extensions/DAGridCoreResource.java
0 → 100644
浏览文件 @
57c914ae
package
cn
.
ibizlab
.
api
.
rest
.
extensions
;
import
cn.ibizlab.core.analysis.domain.DAReport
;
import
cn.ibizlab.core.analysis.service.impl.DAReportServiceImpl
;
import
cn.ibizlab.core.dict.domain.DictOption
;
import
cn.ibizlab.core.dict.service.impl.DictOptionServiceImpl
;
import
cn.ibizlab.core.extensions.service.DACoreService
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONArray
;
import
com.alibaba.fastjson.JSONObject
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
io.swagger.annotations.Api
;
import
lombok.extern.slf4j.Slf4j
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.cache.annotation.Cacheable
;
import
org.springframework.context.annotation.Lazy
;
import
org.springframework.http.ResponseEntity
;
import
org.springframework.util.StringUtils
;
import
org.springframework.web.bind.annotation.*
;
import
java.sql.Timestamp
;
import
java.util.List
;
@Slf4j
@Api
(
tags
=
{
"接口"
})
@RestController
(
"api-dagridcore"
)
@RequestMapping
(
""
)
public
class
DAGridCoreResource
{
@Autowired
private
DACoreService
daCoreService
;
@Autowired
@Lazy
private
DAReportServiceImpl
daReportService
;
@Autowired
@Lazy
private
DictOptionServiceImpl
dictOptionService
;
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/ibizutil/reportdatas"
)
public
ResponseEntity
<
JSONObject
>
getReportdatas
(
@RequestBody
JSONObject
data
)
{
JSONObject
responseJson
=
new
JSONObject
();
String
id
=
data
.
getString
(
"id"
);
String
strLoadDimval
=
StringUtils
.
isEmpty
(
data
.
getString
(
"domin"
))
?
"%"
:
data
.
getString
(
"domin"
);
Timestamp
strLoadStartTime
=
StringUtils
.
isEmpty
(
data
.
getString
(
"startTime"
))
?
daCoreService
.
getDefaultStartTimestamp
()
:
daCoreService
.
getTimestamp
(
data
.
getString
(
"startTime"
));
Timestamp
strLoadEndTime
=
StringUtils
.
isEmpty
(
data
.
getString
(
"endTime"
))
?
daCoreService
.
getDefaultEndTimestamp
()
:
daCoreService
.
getTimestamp
(
data
.
getString
(
"endTime"
));
//获取表头及表单名称
DAReport
daReport
=
daReportService
.
getById
(
id
);
Object
vmcfg
=
JSON
.
parse
(
daReport
.
getConfig
());
String
reportname
=
daReport
.
getReportName
();
String
strDict
=
"CL_DST_REGION"
;
if
(
daReport
!=
null
&&
!
StringUtils
.
isEmpty
(
daReport
.
getDict
()))
{
strDict
=
daReport
.
getDict
();
}
//获取表格数据
JSONObject
jsonObject
=
daCoreService
.
getERPortData
(
daReport
,
strLoadDimval
,
strDict
,
strLoadStartTime
,
strLoadEndTime
,
"default"
);
responseJson
.
put
(
"vmcfg"
,
vmcfg
);
responseJson
.
put
(
"reportname"
,
reportname
);
responseJson
.
put
(
"resportdata"
,
jsonObject
);
responseJson
.
put
(
"dataDict"
,
daReport
.
getDict
());
return
ResponseEntity
.
ok
().
body
(
responseJson
);
}
@RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"/ibizutil/getCodelist"
)
@Cacheable
(
value
=
"getCodelist"
,
key
=
"'getCodelist:'+#p0.getString(\"cid\")"
)
public
ResponseEntity
<
JSONArray
>
getCodelist
(
@RequestBody
JSONObject
data
)
{
JSONArray
result
=
new
JSONArray
();
String
cid
=
data
.
getString
(
"cid"
);
if
(
StringUtils
.
isEmpty
(
cid
)){
log
.
error
(
"未指定字典项过滤条件"
);
return
ResponseEntity
.
ok
().
body
(
result
);
}
QueryWrapper
queryWrapper
=
new
QueryWrapper
();
queryWrapper
.
eq
(
"cid"
,
cid
);
queryWrapper
.
orderByAsc
(
"val"
);
List
<
DictOption
>
list
=
dictOptionService
.
list
(
queryWrapper
);
JSONArray
jsonArray
=
new
JSONArray
();
JSONObject
jsonObject
=
null
;
for
(
DictOption
entity:
list
)
{
jsonObject
=
new
JSONObject
();
jsonObject
.
put
(
"id"
,
entity
.
getValue
());
jsonObject
.
put
(
"value"
,
entity
.
getValue
());
jsonObject
.
put
(
"text"
,
entity
.
getLabel
());
jsonObject
.
put
(
"label"
,
entity
.
getLabel
());
jsonObject
.
put
(
"parentValue"
,
entity
.
getParent
());
jsonObject
.
put
(
"disabled"
,
entity
.
getDisabled
());
jsonArray
.
add
(
jsonObject
);
}
result
=
getTrees
(
jsonArray
,
""
);
return
ResponseEntity
.
ok
().
body
(
result
);
}
/**
* 递归创建树结构数据
* @param jsonArray
* @param parentValue
* @return
*/
public
JSONArray
getTrees
(
JSONArray
jsonArray
,
Object
parentValue
)
{
JSONArray
trees
=
new
JSONArray
();
for
(
int
i
=
0
;
i
<
jsonArray
.
size
();
i
++)
{
JSONObject
jsonObject
=
jsonArray
.
getJSONObject
(
i
);
String
codeItemParentValue
=
jsonObject
.
getString
(
"parentValue"
);
if
(
StringUtils
.
isEmpty
(
codeItemParentValue
))
{
codeItemParentValue
=
""
;
}
if
(
parentValue
.
equals
(
codeItemParentValue
))
{
JSONArray
childCodeItemArray
=
getTrees
(
jsonArray
,
jsonObject
.
getString
(
"value"
));
if
(
childCodeItemArray
.
size
()
>
0
)
{
jsonObject
.
put
(
"children"
,
childCodeItemArray
);
}
trees
.
add
(
jsonObject
);
}
}
return
trees
;
}
}
编辑
预览
Markdown
格式
0%
请重试
or
添加新附件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录