新增JeecgBoot BPM流程自动生成器,包含流程创建、修改及审批人配置功能,支持自然语言描述转化为BPMN XML,并通过API与JeecgBoot系统交互。
This commit is contained in:
343
.trae/skills/jimureport/references/chart-templates.md
Normal file
343
.trae/skills/jimureport/references/chart-templates.md
Normal file
@@ -0,0 +1,343 @@
|
||||
# 图表模板快速参考
|
||||
|
||||
积木报表内置 30+ 图表模板,文件位于 `static/jmreport/desreport_/chartjson/`。
|
||||
可通过 `GET /jmreport/addChart?chartType=bar.simple` 获取模板配置。
|
||||
|
||||
生成图表时,从模板中取 ECharts 配置,修改 `title.text`,清空 `data`(由数据集驱动),然后放入 `chartList[].config`。
|
||||
|
||||
## 图表分类速查
|
||||
|
||||
### 柱状图 (Bar)
|
||||
|
||||
| chartType | 说明 | 数据集要求 |
|
||||
|-----------|------|-----------|
|
||||
| `bar.simple` | 单系列柱状图 | `name, value` |
|
||||
| `bar.multi` | 多系列柱状图 | `name, value, type` |
|
||||
| `bar.stack` | 堆叠柱状图 | `name, value, type` |
|
||||
| `bar.horizontal` | 横向柱状图 | `name, value` |
|
||||
| `bar.multi.horizontal` | 横向多系列 | `name, value, type` |
|
||||
| `bar.stack.horizontal` | 横向堆叠 | `name, value, type` |
|
||||
| `bar.negative` | 正负柱状图 | `name, value, type` |
|
||||
| `bar.background` | 带背景柱状图 | `name, value` |
|
||||
|
||||
### 折线图 (Line)
|
||||
|
||||
| chartType | 说明 | 数据集要求 |
|
||||
|-----------|------|-----------|
|
||||
| `line.simple` | 单系列折线图 | `name, value` |
|
||||
| `line.multi` | 多系列折线图 | `name, value, type` |
|
||||
| `line.smooth` | 平滑曲线图 | `name, value` |
|
||||
| `line.area` | 面积图 | `name, value, type` |
|
||||
| `line.step` | 阶梯折线图 | `name, value` |
|
||||
|
||||
### 饼图 (Pie)
|
||||
|
||||
| chartType | 说明 | 数据集要求 |
|
||||
|-----------|------|-----------|
|
||||
| `pie.simple` | 饼图 | `name, value` |
|
||||
| `pie.doughnut` | 环形图 | `name, value` |
|
||||
| `pie.rose` | 玫瑰图(南丁格尔) | `name, value` |
|
||||
|
||||
### 混合图
|
||||
|
||||
| chartType | 说明 | 数据集要求 |
|
||||
|-----------|------|-----------|
|
||||
| `mixed.linebar` | 柱状+折线混合 | `name, value, type` |
|
||||
|
||||
### 其他图表
|
||||
|
||||
| chartType | 说明 | 数据集要求 |
|
||||
|-----------|------|-----------|
|
||||
| `gauge.simple` | 仪表盘 | `name, value` |
|
||||
| `gauge.simple180` | 半圆仪表盘 | `name, value` |
|
||||
| `radar.basic` | 雷达图 | 特殊(indicator) |
|
||||
| `radar.custom` | 自定义雷达图 | 特殊 |
|
||||
| `funnel.simple` | 漏斗图 | `name, value` |
|
||||
| `funnel.pyramid` | 金字塔图 | `name, value` |
|
||||
| `scatter.simple` | 散点图 | 特殊 |
|
||||
| `scatter.bubble` | 气泡图 | 特殊 |
|
||||
| `map.simple` | 地图 | 特殊 |
|
||||
| `map.scatter` | 地图散点 | 特殊 |
|
||||
| `graph.simple` | 关系图 | 特殊(需两个数据集) |
|
||||
| `pictorial.spirits` | 象形柱图 | `name, value` |
|
||||
|
||||
## 常用图表 ECharts 配置模板
|
||||
|
||||
### bar.simple — 单系列柱状图
|
||||
|
||||
```python
|
||||
{
|
||||
"title": {"show": True, "text": "标题", "left": "left", "top": "5",
|
||||
"padding": [5,20,5,20],
|
||||
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
|
||||
"grid": {"left": 60, "top": 60, "right": 100, "bottom": 60},
|
||||
"tooltip": {"show": True, "textStyle": {"color": "#fff", "fontSize": 18}},
|
||||
"xAxis": {"show": True, "name": "", "data": [],
|
||||
"axisLabel": {"textStyle": {"fontSize": 12, "color": "#333"}},
|
||||
"axisLine": {"lineStyle": {"color": "#333"}}},
|
||||
"yAxis": {"show": True, "name": "",
|
||||
"axisLabel": {"textStyle": {"fontSize": 12, "color": "#333"}},
|
||||
"axisLine": {"lineStyle": {"color": "#333"}}},
|
||||
"series": [{"name": "", "type": "bar", "data": [],
|
||||
"barWidth": 50, "barMinHeight": 2,
|
||||
"itemStyle": {"barBorderRadius": 0, "color": "#c43632"}}]
|
||||
}
|
||||
```
|
||||
|
||||
### bar.multi — 多系列柱状图
|
||||
|
||||
```python
|
||||
{
|
||||
"title": {"show": True, "text": "标题", "left": "left",
|
||||
"padding": [5,20,5,20],
|
||||
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
|
||||
"legend": {"show": True, "data": [], "top": "top", "left": "center",
|
||||
"orient": "horizontal", "padding": [25,20,25,10],
|
||||
"textStyle": {"color": "#333", "fontSize": 12}},
|
||||
"grid": {"left": 60, "top": 60, "right": 100, "bottom": 60},
|
||||
"tooltip": {"show": True, "trigger": "axis",
|
||||
"axisPointer": {"type": "shadow"},
|
||||
"textStyle": {"color": "#fff", "fontSize": 18}},
|
||||
"xAxis": {"show": True, "type": "category", "data": [],
|
||||
"axisLabel": {"textStyle": {"fontSize": 12, "color": "#333"}},
|
||||
"axisLine": {"lineStyle": {"color": "#333"}}},
|
||||
"yAxis": {"show": True,
|
||||
"axisLabel": {"textStyle": {"fontSize": 12, "color": "#333"}},
|
||||
"axisLine": {"lineStyle": {"color": "#333"}}},
|
||||
"series": [
|
||||
{"name": "系列1", "type": "bar", "data": [], "barWidth": 0, "barMinHeight": 2,
|
||||
"label": {"show": True, "position": "top", "textStyle": {"color": "black", "fontSize": 12}},
|
||||
"itemStyle": {"barBorderRadius": 0, "color": ""}},
|
||||
{"name": "系列2", "type": "bar", "data": [], "barWidth": 0, "barMinHeight": 2,
|
||||
"label": {"show": True, "position": "top", "textStyle": {"color": "black", "fontSize": 12}},
|
||||
"itemStyle": {"barBorderRadius": 0, "color": ""}}
|
||||
]
|
||||
}
|
||||
```
|
||||
|
||||
### line.simple — 单系列折线图
|
||||
|
||||
```python
|
||||
{
|
||||
"title": {"show": True, "text": "标题",
|
||||
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
|
||||
"grid": {"left": 60, "top": 60, "right": 100, "bottom": 60},
|
||||
"xAxis": {"show": True, "data": []},
|
||||
"yAxis": {"show": True, "name": ""},
|
||||
"series": [{"name": "", "type": "line", "data": [],
|
||||
"smooth": False, "showSymbol": True, "symbolSize": 5,
|
||||
"lineStyle": {"width": 2, "color": "#c43632"}}]
|
||||
}
|
||||
```
|
||||
|
||||
### pie.simple — 饼图
|
||||
|
||||
```python
|
||||
{
|
||||
"title": {"show": True, "text": "标题",
|
||||
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
|
||||
"tooltip": {"show": True, "formatter": "{a} <br/>{b} : {c}"},
|
||||
"legend": {"show": True, "data": [], "orient": "horizontal",
|
||||
"textStyle": {"color": "#333", "fontSize": 12}},
|
||||
"series": [{"name": "数据", "type": "pie",
|
||||
"radius": "55%", "minAngle": 0,
|
||||
"center": [320, 180],
|
||||
"label": {"show": True, "position": "outside"},
|
||||
"data": []}]
|
||||
}
|
||||
```
|
||||
|
||||
### pie.doughnut — 环形图
|
||||
|
||||
```python
|
||||
{
|
||||
"title": {"show": True, "text": "标题",
|
||||
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
|
||||
"tooltip": {"show": True, "formatter": "{a} <br/>{b} : {c}"},
|
||||
"legend": {"show": True, "data": [], "orient": "horizontal",
|
||||
"textStyle": {"color": "#333", "fontSize": 12}},
|
||||
"series": [{"name": "数据", "type": "pie",
|
||||
"isRadius": True,
|
||||
"radius": ["45%", "55%"], # 内外半径 → 环形
|
||||
"minAngle": 0, "roseType": "", "isRose": False,
|
||||
"center": [320, 180],
|
||||
"label": {"show": True, "position": "outside"},
|
||||
"data": []}]
|
||||
}
|
||||
```
|
||||
|
||||
### mixed.linebar — 柱线混合图
|
||||
|
||||
```python
|
||||
{
|
||||
"chartType": "linebar",
|
||||
"title": {"show": True, "text": "标题",
|
||||
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
|
||||
"legend": {"data": []},
|
||||
"xAxis": {"type": "category", "data": []},
|
||||
"yAxis": [
|
||||
{"type": "value", "name": "左轴"},
|
||||
{"type": "value", "name": "右轴"}
|
||||
],
|
||||
"series": [
|
||||
{"name": "柱状", "type": "bar", "data": []},
|
||||
{"name": "折线", "type": "line", "data": []},
|
||||
{"name": "右轴数据", "type": "bar", "yAxisIndex": 1, "data": []}
|
||||
]
|
||||
}
|
||||
```
|
||||
|
||||
### gauge.simple — 仪表盘
|
||||
|
||||
```python
|
||||
{
|
||||
"title": {"show": True, "text": "标题",
|
||||
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
|
||||
"tooltip": {"show": True, "formatter": "{b} : {c}"},
|
||||
"series": [{"name": "业务指标", "type": "gauge",
|
||||
"radius": "75%", "center": [330, 200],
|
||||
"itemStyle": {"color": "#63869E"},
|
||||
"pointer": {"show": True},
|
||||
"detail": {"formatter": "{value}%",
|
||||
"textStyle": {"color": "rgba(0,0,0,1)", "fontSize": 25}},
|
||||
"axisLine": {"lineStyle": {
|
||||
"color": [[0.2, "#91c7ae"], [0.8, "#63869E"], [1, "#C23531"]],
|
||||
"width": 25}},
|
||||
"data": [{"value": 50, "name": "完成率"}]}]
|
||||
}
|
||||
```
|
||||
|
||||
### funnel.simple — 漏斗图
|
||||
|
||||
```python
|
||||
{
|
||||
"title": {"show": True, "text": "标题",
|
||||
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
|
||||
"legend": {"show": True, "data": []},
|
||||
"tooltip": {"show": True, "trigger": "item", "formatter": "{b} : {c}"},
|
||||
"series": [{"name": "漏斗图", "type": "funnel",
|
||||
"left": "10%", "top": 60, "bottom": 60, "width": "80%",
|
||||
"sort": "descending", "gap": 2, "orient": "vertical",
|
||||
"label": {"show": True, "position": "inside",
|
||||
"textStyle": {"fontSize": 16}},
|
||||
"itemStyle": {"borderColor": "#fff", "borderWidth": 1},
|
||||
"data": []}]
|
||||
}
|
||||
```
|
||||
|
||||
### radar.basic — 雷达图
|
||||
|
||||
```python
|
||||
{
|
||||
"title": {"show": True, "text": "标题",
|
||||
"textStyle": {"fontSize": 18, "fontWeight": "bolder", "color": "#c23531"}},
|
||||
"legend": {"show": True, "data": []},
|
||||
"tooltip": {"show": True},
|
||||
"radar": [{"shape": "polygon", "center": [320, 200],
|
||||
"name": {"formatter": "【{value}】",
|
||||
"textStyle": {"fontSize": 14, "color": "#72ACD1"}},
|
||||
"indicator": [
|
||||
{"name": "维度1", "max": 100},
|
||||
{"name": "维度2", "max": 100},
|
||||
{"name": "维度3", "max": 100}
|
||||
]}],
|
||||
"series": [{"name": "", "type": "radar",
|
||||
"data": [{"value": [80, 60, 70], "name": "系列1"}]}]
|
||||
}
|
||||
```
|
||||
|
||||
## 数据集 SQL 映射规则
|
||||
|
||||
图表数据集使用固定的 `name`/`value`/`type` 字段映射:
|
||||
|
||||
```sql
|
||||
-- 单系列(bar.simple, line.simple, pie.simple 等)
|
||||
SELECT product_name AS name, sales_amount AS value, '' AS type
|
||||
FROM sales_table
|
||||
|
||||
-- 多系列(bar.multi, line.multi, mixed.linebar 等)
|
||||
SELECT month AS name, amount AS value, category AS type
|
||||
FROM sales_table
|
||||
|
||||
-- 仪表盘(gauge)
|
||||
SELECT '完成率' AS name, ROUND(done*100/total) AS value, '' AS type
|
||||
FROM task_summary
|
||||
|
||||
-- 漏斗图(funnel)
|
||||
SELECT stage AS name, count AS value, '' AS type
|
||||
FROM funnel_data ORDER BY count DESC
|
||||
```
|
||||
|
||||
## 快速生成图表的 Python 代码
|
||||
|
||||
```python
|
||||
def create_chart(chart_type, title, db_code, db_id, row_start, col_start,
|
||||
rows=10, cols=5, width="650", height="350"):
|
||||
"""快速生成图表配置"""
|
||||
layer_id = "chart_" + gen_id()
|
||||
|
||||
# 根据类型选择基础配置
|
||||
base_configs = {
|
||||
"bar.simple": {
|
||||
"title": {"text": title, "left": "center", "top": "10"},
|
||||
"tooltip": {"trigger": "axis", "axisPointer": {"type": "shadow"}},
|
||||
"grid": {"left": "3%", "right": "4%", "bottom": "3%", "containLabel": True},
|
||||
"xAxis": [{"type": "category", "data": []}],
|
||||
"yAxis": [{"type": "value"}],
|
||||
"series": [{"type": "bar", "data": [], "barWidth": "40%"}]
|
||||
},
|
||||
"pie.simple": {
|
||||
"title": {"text": title, "left": "center"},
|
||||
"tooltip": {"trigger": "item", "formatter": "{b}: {c} ({d}%)"},
|
||||
"legend": {"bottom": "5%", "left": "center"},
|
||||
"series": [{"type": "pie", "radius": "55%", "center": ["50%", "50%"], "data": []}]
|
||||
},
|
||||
"line.simple": {
|
||||
"title": {"text": title, "left": "center"},
|
||||
"tooltip": {"trigger": "axis"},
|
||||
"grid": {"left": "3%", "right": "4%", "bottom": "3%", "containLabel": True},
|
||||
"xAxis": [{"type": "category", "data": []}],
|
||||
"yAxis": [{"type": "value"}],
|
||||
"series": [{"type": "line", "smooth": True, "data": []}]
|
||||
},
|
||||
"gauge.simple": {
|
||||
"title": {"text": title, "left": "center"},
|
||||
"series": [{"type": "gauge", "radius": "75%",
|
||||
"detail": {"formatter": "{value}%"},
|
||||
"data": [{"value": 0, "name": ""}]}]
|
||||
}
|
||||
}
|
||||
config = base_configs.get(chart_type, base_configs["bar.simple"])
|
||||
|
||||
# virtual cells
|
||||
row_end = row_start + rows - 1
|
||||
col_end = col_start + cols - 1
|
||||
virtual_cells = [[r,c] for r in range(row_start, row_end+1) for c in range(col_start, col_end+1)]
|
||||
|
||||
# rows 占位
|
||||
chart_rows = {}
|
||||
for r in range(row_start, row_end + 1):
|
||||
cells = {}
|
||||
for c in range(col_start, col_end + 1):
|
||||
cells[str(c)] = {"text": " ", "virtual": layer_id}
|
||||
chart_rows[str(r)] = {"cells": cells}
|
||||
|
||||
chart_item = {
|
||||
"row": row_start, "col": col_start, "colspan": 0, "rowspan": 0,
|
||||
"width": width, "height": height,
|
||||
"config": json.dumps(config, ensure_ascii=False),
|
||||
"url": "",
|
||||
"extData": {
|
||||
"chartType": chart_type, "dataType": "sql",
|
||||
"dataId": str(db_id), "dbCode": db_code,
|
||||
"axisX": "name", "axisY": "value", "series": "type",
|
||||
"xText": "", "yText": "", "apiStatus": "1"
|
||||
},
|
||||
"layer_id": layer_id,
|
||||
"offsetX": 0, "offsetY": 0,
|
||||
"backgroud": {"enabled": False, "color": "#fff", "image": ""},
|
||||
"virtualCellRange": virtual_cells
|
||||
}
|
||||
|
||||
return chart_item, chart_rows
|
||||
```
|
||||
Reference in New Issue
Block a user