Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
D
dataease
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
zhu
dataease
Commits
2edef243
Unverified
提交
2edef243
authored
8月 09, 2021
作者:
taojinlong
提交者:
GitHub
8月 09, 2021
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'dev' into pr@dev@sqlserver
上级
cbe49654
5535df32
隐藏空白字符变更
内嵌
并排
正在显示
7 个修改的文件
包含
251 行增加
和
25 行删除
+251
-25
AxisChartDataDTO.java
...src/main/java/io/dataease/dto/chart/AxisChartDataDTO.java
+17
-0
ChartDimensionDTO.java
...rc/main/java/io/dataease/dto/chart/ChartDimensionDTO.java
+13
-0
ChartQuotaDTO.java
...nd/src/main/java/io/dataease/dto/chart/ChartQuotaDTO.java
+12
-0
ScatterChartDataDTO.java
.../main/java/io/dataease/dto/chart/ScatterChartDataDTO.java
+17
-0
ChartViewService.java
...main/java/io/dataease/service/chart/ChartViewService.java
+174
-13
funnel.js
frontend/src/views/chart/chart/funnel/funnel.js
+6
-4
pie.js
frontend/src/views/chart/chart/pie/pie.js
+12
-8
没有找到文件。
backend/src/main/java/io/dataease/dto/chart/AxisChartDataDTO.java
0 → 100644
浏览文件 @
2edef243
package
io
.
dataease
.
dto
.
chart
;
import
lombok.Data
;
import
java.math.BigDecimal
;
import
java.util.List
;
/**
* @Author gin
* @Date 2021/8/9 10:14 上午
*/
@Data
public
class
AxisChartDataDTO
{
private
BigDecimal
value
;
private
List
<
ChartDimensionDTO
>
dimensionList
;
private
List
<
ChartQuotaDTO
>
quotaList
;
}
backend/src/main/java/io/dataease/dto/chart/ChartDimensionDTO.java
0 → 100644
浏览文件 @
2edef243
package
io
.
dataease
.
dto
.
chart
;
import
lombok.Data
;
/**
* @Author gin
* @Date 2021/8/9 10:15 上午
*/
@Data
public
class
ChartDimensionDTO
{
private
String
id
;
private
String
value
;
}
backend/src/main/java/io/dataease/dto/chart/ChartQuotaDTO.java
0 → 100644
浏览文件 @
2edef243
package
io
.
dataease
.
dto
.
chart
;
import
lombok.Data
;
/**
* @Author gin
* @Date 2021/8/9 10:16 上午
*/
@Data
public
class
ChartQuotaDTO
{
private
String
id
;
}
backend/src/main/java/io/dataease/dto/chart/ScatterChartDataDTO.java
0 → 100644
浏览文件 @
2edef243
package
io
.
dataease
.
dto
.
chart
;
import
lombok.Data
;
import
java.math.BigDecimal
;
import
java.util.List
;
/**
* @Author gin
* @Date 2021/8/9 10:14 上午
*/
@Data
public
class
ScatterChartDataDTO
{
private
Object
[]
value
;
private
List
<
ChartDimensionDTO
>
dimensionList
;
private
List
<
ChartQuotaDTO
>
quotaList
;
}
backend/src/main/java/io/dataease/service/chart/ChartViewService.java
浏览文件 @
2edef243
...
...
@@ -365,6 +365,8 @@ public class ChartViewService {
mapChart
=
transStackChartData
(
xAxis
,
yAxis
,
view
,
data
,
extStack
);
}
else
if
(
StringUtils
.
containsIgnoreCase
(
view
.
getType
(),
"scatter"
))
{
mapChart
=
transScatterData
(
xAxis
,
yAxis
,
view
,
data
,
extBubble
);
}
else
if
(
StringUtils
.
containsIgnoreCase
(
view
.
getType
(),
"radar"
))
{
mapChart
=
transRadarChartData
(
xAxis
,
yAxis
,
view
,
data
);
}
else
{
mapChart
=
transChartData
(
xAxis
,
yAxis
,
view
,
data
);
}
...
...
@@ -421,6 +423,63 @@ public class ChartViewService {
private
Map
<
String
,
Object
>
transChartData
(
List
<
ChartViewFieldDTO
>
xAxis
,
List
<
ChartViewFieldDTO
>
yAxis
,
ChartViewWithBLOBs
view
,
List
<
String
[]>
data
)
{
Map
<
String
,
Object
>
map
=
new
HashMap
<>();
List
<
String
>
x
=
new
ArrayList
<>();
List
<
Series
>
series
=
new
ArrayList
<>();
for
(
ChartViewFieldDTO
y
:
yAxis
)
{
Series
series1
=
new
Series
();
series1
.
setName
(
y
.
getName
());
series1
.
setType
(
view
.
getType
());
series1
.
setData
(
new
ArrayList
<>());
series
.
add
(
series1
);
}
for
(
int
i1
=
0
;
i1
<
data
.
size
();
i1
++)
{
String
[]
d
=
data
.
get
(
i1
);
StringBuilder
a
=
new
StringBuilder
();
for
(
int
i
=
xAxis
.
size
();
i
<
xAxis
.
size
()
+
yAxis
.
size
();
i
++)
{
List
<
ChartDimensionDTO
>
dimensionList
=
new
ArrayList
<>();
List
<
ChartQuotaDTO
>
quotaList
=
new
ArrayList
<>();
AxisChartDataDTO
axisChartDataDTO
=
new
AxisChartDataDTO
();
for
(
int
j
=
0
;
j
<
xAxis
.
size
();
j
++)
{
ChartDimensionDTO
chartDimensionDTO
=
new
ChartDimensionDTO
();
chartDimensionDTO
.
setId
(
xAxis
.
get
(
j
).
getId
());
chartDimensionDTO
.
setValue
(
d
[
j
]);
dimensionList
.
add
(
chartDimensionDTO
);
}
axisChartDataDTO
.
setDimensionList
(
dimensionList
);
int
j
=
i
-
xAxis
.
size
();
ChartQuotaDTO
chartQuotaDTO
=
new
ChartQuotaDTO
();
chartQuotaDTO
.
setId
(
yAxis
.
get
(
j
).
getId
());
quotaList
.
add
(
chartQuotaDTO
);
axisChartDataDTO
.
setQuotaList
(
quotaList
);
try
{
axisChartDataDTO
.
setValue
(
new
BigDecimal
(
StringUtils
.
isEmpty
(
d
[
i
])
?
"0"
:
d
[
i
]));
}
catch
(
Exception
e
)
{
axisChartDataDTO
.
setValue
(
new
BigDecimal
(
0
));
}
series
.
get
(
j
).
getData
().
add
(
axisChartDataDTO
);
}
for
(
int
i
=
0
;
i
<
xAxis
.
size
();
i
++)
{
if
(
i
==
xAxis
.
size
()
-
1
)
{
a
.
append
(
d
[
i
]);
}
else
{
a
.
append
(
d
[
i
]).
append
(
"\n"
);
}
}
x
.
add
(
a
.
toString
());
}
map
.
put
(
"x"
,
x
);
map
.
put
(
"series"
,
series
);
return
map
;
}
// radar图
private
Map
<
String
,
Object
>
transRadarChartData
(
List
<
ChartViewFieldDTO
>
xAxis
,
List
<
ChartViewFieldDTO
>
yAxis
,
ChartViewWithBLOBs
view
,
List
<
String
[]>
data
)
{
Map
<
String
,
Object
>
map
=
new
HashMap
<>();
List
<
String
>
x
=
new
ArrayList
<>();
List
<
Series
>
series
=
new
ArrayList
<>();
for
(
ChartViewFieldDTO
y
:
yAxis
)
{
...
...
@@ -464,7 +523,9 @@ public class ChartViewService {
List
<
Series
>
series
=
new
ArrayList
<>();
if
(
CollectionUtils
.
isNotEmpty
(
extStack
))
{
AxisChartDataDTO
defaultAxisChartDataDTO
=
new
AxisChartDataDTO
();
BigDecimal
defaultValue
=
StringUtils
.
containsIgnoreCase
(
view
.
getType
(),
"line"
)
?
new
BigDecimal
(
0
)
:
null
;
defaultAxisChartDataDTO
.
setValue
(
defaultValue
);
// 构建横轴
for
(
String
[]
d
:
data
)
{
StringBuilder
a
=
new
StringBuilder
();
...
...
@@ -489,7 +550,7 @@ public class ChartViewService {
series1
.
setType
(
view
.
getType
());
List
<
Object
>
list
=
new
ArrayList
<>();
for
(
int
i
=
0
;
i
<
x
.
size
();
i
++)
{
list
.
add
(
default
Value
);
list
.
add
(
default
AxisChartDataDTO
);
}
series1
.
setData
(
list
);
series
.
add
(
series1
);
...
...
@@ -509,9 +570,31 @@ public class ChartViewService {
}
if
(
StringUtils
.
equals
(
a
.
toString
(),
x
.
get
(
i
)))
{
if
(
row
.
length
>
xAxis
.
size
()
+
extStack
.
size
())
{
List
<
ChartDimensionDTO
>
dimensionList
=
new
ArrayList
<>();
List
<
ChartQuotaDTO
>
quotaList
=
new
ArrayList
<>();
AxisChartDataDTO
axisChartDataDTO
=
new
AxisChartDataDTO
();
ChartQuotaDTO
chartQuotaDTO
=
new
ChartQuotaDTO
();
chartQuotaDTO
.
setId
(
yAxis
.
get
(
0
).
getId
());
quotaList
.
add
(
chartQuotaDTO
);
axisChartDataDTO
.
setQuotaList
(
quotaList
);
for
(
int
k
=
0
;
k
<
xAxis
.
size
();
k
++)
{
ChartDimensionDTO
chartDimensionDTO
=
new
ChartDimensionDTO
();
chartDimensionDTO
.
setId
(
xAxis
.
get
(
k
).
getId
());
chartDimensionDTO
.
setValue
(
row
[
k
]);
dimensionList
.
add
(
chartDimensionDTO
);
}
ChartDimensionDTO
chartDimensionDTO
=
new
ChartDimensionDTO
();
chartDimensionDTO
.
setId
(
extStack
.
get
(
0
).
getId
());
chartDimensionDTO
.
setValue
(
row
[
xAxis
.
size
()]);
dimensionList
.
add
(
chartDimensionDTO
);
axisChartDataDTO
.
setDimensionList
(
dimensionList
);
String
s
=
row
[
xAxis
.
size
()
+
extStack
.
size
()];
if
(
StringUtils
.
isNotEmpty
(
s
))
{
ss
.
getData
().
set
(
i
,
new
BigDecimal
(
s
));
axisChartDataDTO
.
setValue
(
new
BigDecimal
(
s
));
ss
.
getData
().
set
(
i
,
axisChartDataDTO
);
}
}
break
;
...
...
@@ -528,8 +611,35 @@ public class ChartViewService {
series1
.
setData
(
new
ArrayList
<>());
series
.
add
(
series1
);
}
for
(
String
[]
d
:
data
)
{
for
(
int
i1
=
0
;
i1
<
data
.
size
();
i1
++)
{
String
[]
d
=
data
.
get
(
i1
);
StringBuilder
a
=
new
StringBuilder
();
for
(
int
i
=
xAxis
.
size
();
i
<
xAxis
.
size
()
+
yAxis
.
size
();
i
++)
{
List
<
ChartDimensionDTO
>
dimensionList
=
new
ArrayList
<>();
List
<
ChartQuotaDTO
>
quotaList
=
new
ArrayList
<>();
AxisChartDataDTO
axisChartDataDTO
=
new
AxisChartDataDTO
();
for
(
int
j
=
0
;
j
<
xAxis
.
size
();
j
++)
{
ChartDimensionDTO
chartDimensionDTO
=
new
ChartDimensionDTO
();
chartDimensionDTO
.
setId
(
xAxis
.
get
(
j
).
getId
());
chartDimensionDTO
.
setValue
(
d
[
j
]);
dimensionList
.
add
(
chartDimensionDTO
);
}
axisChartDataDTO
.
setDimensionList
(
dimensionList
);
int
j
=
i
-
xAxis
.
size
();
ChartQuotaDTO
chartQuotaDTO
=
new
ChartQuotaDTO
();
chartQuotaDTO
.
setId
(
yAxis
.
get
(
j
).
getId
());
quotaList
.
add
(
chartQuotaDTO
);
axisChartDataDTO
.
setQuotaList
(
quotaList
);
try
{
axisChartDataDTO
.
setValue
(
new
BigDecimal
(
StringUtils
.
isEmpty
(
d
[
i
])
?
"0"
:
d
[
i
]));
}
catch
(
Exception
e
)
{
axisChartDataDTO
.
setValue
(
new
BigDecimal
(
0
));
}
series
.
get
(
j
).
getData
().
add
(
axisChartDataDTO
);
}
for
(
int
i
=
0
;
i
<
xAxis
.
size
();
i
++)
{
if
(
i
==
xAxis
.
size
()
-
1
)
{
a
.
append
(
d
[
i
]);
...
...
@@ -538,14 +648,6 @@ public class ChartViewService {
}
}
x
.
add
(
a
.
toString
());
for
(
int
i
=
xAxis
.
size
();
i
<
xAxis
.
size
()
+
yAxis
.
size
();
i
++)
{
int
j
=
i
-
xAxis
.
size
();
try
{
series
.
get
(
j
).
getData
().
add
(
new
BigDecimal
(
StringUtils
.
isEmpty
(
d
[
i
])
?
"0"
:
d
[
i
]));
}
catch
(
Exception
e
)
{
series
.
get
(
j
).
getData
().
add
(
new
BigDecimal
(
0
));
}
}
}
}
...
...
@@ -567,7 +669,66 @@ public class ChartViewService {
series1
.
setData
(
new
ArrayList
<>());
series
.
add
(
series1
);
}
for
(
String
[]
d
:
data
)
{
for
(
int
i1
=
0
;
i1
<
data
.
size
();
i1
++)
{
String
[]
d
=
data
.
get
(
i1
);
StringBuilder
a
=
new
StringBuilder
();
for
(
int
i
=
0
;
i
<
xAxis
.
size
();
i
++)
{
if
(
i
==
xAxis
.
size
()
-
1
)
{
a
.
append
(
d
[
i
]);
}
else
{
a
.
append
(
d
[
i
]).
append
(
"\n"
);
}
}
x
.
add
(
a
.
toString
());
for
(
int
i
=
xAxis
.
size
();
i
<
xAxis
.
size
()
+
yAxis
.
size
();
i
++)
{
List
<
ChartDimensionDTO
>
dimensionList
=
new
ArrayList
<>();
List
<
ChartQuotaDTO
>
quotaList
=
new
ArrayList
<>();
ScatterChartDataDTO
scatterChartDataDTO
=
new
ScatterChartDataDTO
();
for
(
int
j
=
0
;
j
<
xAxis
.
size
();
j
++)
{
ChartDimensionDTO
chartDimensionDTO
=
new
ChartDimensionDTO
();
chartDimensionDTO
.
setId
(
xAxis
.
get
(
j
).
getId
());
chartDimensionDTO
.
setValue
(
d
[
j
]);
dimensionList
.
add
(
chartDimensionDTO
);
}
scatterChartDataDTO
.
setDimensionList
(
dimensionList
);
int
j
=
i
-
xAxis
.
size
();
ChartQuotaDTO
chartQuotaDTO
=
new
ChartQuotaDTO
();
chartQuotaDTO
.
setId
(
yAxis
.
get
(
j
).
getId
());
quotaList
.
add
(
chartQuotaDTO
);
scatterChartDataDTO
.
setQuotaList
(
quotaList
);
// try {
// axisChartDataDTO.setValue(new BigDecimal(StringUtils.isEmpty(d[i]) ? "0" : d[i]));
// } catch (Exception e) {
// axisChartDataDTO.setValue(new BigDecimal(0));
// }
if
(
CollectionUtils
.
isNotEmpty
(
extBubble
)
&&
extBubble
.
size
()
>
0
)
{
try
{
scatterChartDataDTO
.
setValue
(
new
Object
[]{
a
.
toString
(),
new
BigDecimal
(
StringUtils
.
isEmpty
(
d
[
i
])
?
"0"
:
d
[
i
]),
new
BigDecimal
(
StringUtils
.
isEmpty
(
d
[
xAxis
.
size
()
+
yAxis
.
size
()])
?
"0"
:
d
[
xAxis
.
size
()
+
yAxis
.
size
()])
});
}
catch
(
Exception
e
)
{
scatterChartDataDTO
.
setValue
(
new
Object
[]{
a
.
toString
(),
new
BigDecimal
(
0
),
new
BigDecimal
(
0
)});
}
}
else
{
try
{
scatterChartDataDTO
.
setValue
(
new
Object
[]{
a
.
toString
(),
new
BigDecimal
(
StringUtils
.
isEmpty
(
d
[
i
])
?
"0"
:
d
[
i
])
});
}
catch
(
Exception
e
)
{
scatterChartDataDTO
.
setValue
(
new
Object
[]{
a
.
toString
(),
new
BigDecimal
(
0
)});
}
}
series
.
get
(
j
).
getData
().
add
(
scatterChartDataDTO
);
}
}
/*for (String[] d : data) {
StringBuilder a = new StringBuilder();
for (int i = 0; i < xAxis.size(); i++) {
if (i == xAxis.size() - 1) {
...
...
@@ -600,7 +761,7 @@ public class ChartViewService {
}
}
}
}
}
*/
map
.
put
(
"x"
,
x
);
map
.
put
(
"series"
,
series
);
...
...
frontend/src/views/chart/chart/funnel/funnel.js
浏览文件 @
2edef243
...
...
@@ -34,10 +34,12 @@ export function baseFunnelOption(chart_option, chart) {
// max value
chart_option
.
series
[
0
].
max
=
Math
.
max
.
apply
(
Math
,
valueArr
)
for
(
let
i
=
0
;
i
<
valueArr
.
length
;
i
++
)
{
const
y
=
{
name
:
chart
.
data
.
x
[
i
],
value
:
valueArr
[
i
]
}
// const y = {
// name: chart.data.x[i],
// value: valueArr[i]
// }
const
y
=
valueArr
[
i
]
y
.
name
=
chart
.
data
.
x
[
i
]
// color
y
.
itemStyle
=
{
color
:
hexColorToRGBA
(
customAttr
.
color
.
colors
[
i
%
9
],
customAttr
.
color
.
alpha
)
...
...
frontend/src/views/chart/chart/pie/pie.js
浏览文件 @
2edef243
...
...
@@ -33,10 +33,12 @@ export function basePieOption(chart_option, chart) {
}
const
valueArr
=
chart
.
data
.
series
[
0
].
data
for
(
let
i
=
0
;
i
<
valueArr
.
length
;
i
++
)
{
const
y
=
{
name
:
chart
.
data
.
x
[
i
],
value
:
valueArr
[
i
]
}
// const y = {
// name: chart.data.x[i],
// value: valueArr[i]
// }
const
y
=
valueArr
[
i
]
y
.
name
=
chart
.
data
.
x
[
i
]
// color
y
.
itemStyle
=
{
color
:
hexColorToRGBA
(
customAttr
.
color
.
colors
[
i
%
9
],
customAttr
.
color
.
alpha
),
...
...
@@ -84,10 +86,12 @@ export function rosePieOption(chart_option, chart) {
}
const
valueArr
=
chart
.
data
.
series
[
0
].
data
for
(
let
i
=
0
;
i
<
valueArr
.
length
;
i
++
)
{
const
y
=
{
name
:
chart
.
data
.
x
[
i
],
value
:
valueArr
[
i
]
}
// const y = {
// name: chart.data.x[i],
// value: valueArr[i]
// }
const
y
=
valueArr
[
i
]
y
.
name
=
chart
.
data
.
x
[
i
]
// color
y
.
itemStyle
=
{
color
:
hexColorToRGBA
(
customAttr
.
color
.
colors
[
i
%
9
],
customAttr
.
color
.
alpha
),
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论