1
|
1
|
(function () {
|
2
|
|
- // Adds Atlassian shapes
|
3
|
|
- // 图表
|
4
|
|
- Sidebar.prototype.addChartsPalette = function () {
|
5
|
|
- var s = 'html=1;shadow=0;dashed=0;shape=mxgraph.atlassian.';
|
6
|
|
- var s2 = 'html=1;shadow=0;dashed=0;fillColor=none;strokeColor=none;shape=mxgraph.bootstrap.rect;';
|
7
|
|
- var s3 = mxConstants.STYLE_STROKEWIDTH + '=1;shadow=0;dashed=0;align=center;html=1;' + mxConstants.STYLE_SHAPE + "=mxgraph.mockup.";
|
8
|
|
- var gn = 'mxgraph.charts';
|
9
|
|
- var dt = 'charts ';
|
10
|
|
- var sb = this;
|
11
|
|
- this.setCurrentSearchEntryLibrary('charts');
|
12
|
|
-
|
13
|
|
- const now = () => Date.now
|
14
|
|
- var fns = [
|
15
|
|
- this.addEntry('charts', mxUtils.bind(this, function () {
|
16
|
|
- const nodeId = `echarts__${ now() }`
|
17
|
|
- var cell = new mxCell(`<div style="color: red" id="${ nodeId }">${ now() }</div>`, new mxGeometry(0, 0, 160, 20), 'text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;overflow=hidden;');
|
18
|
|
- cell.setVertex(true)
|
19
|
|
- return this.createVertexTemplateFromCells([cell], cell.geometry.width, cell.geometry.height, 'charts');
|
20
|
|
- })),
|
21
|
|
- ];
|
22
|
|
-
|
23
|
|
- this.addPalette('charts', '图表', false, mxUtils.bind(this, function (content) {
|
24
|
|
- for (var i = 0; i < fns.length; i++) {
|
25
|
|
- content.appendChild(fns[i](content));
|
26
|
|
- }
|
27
|
|
- }));
|
28
|
|
-
|
29
|
|
- this.setCurrentSearchEntryLibrary();
|
30
|
|
- };
|
|
2
|
+ // Adds Atlassian shapes
|
|
3
|
+ // 图表
|
|
4
|
+ Sidebar.prototype.addChartsPalette = function () {
|
|
5
|
+
|
|
6
|
+ const generatorId = () => `echarts__instance__${ Date.now() }`
|
|
7
|
+
|
|
8
|
+ const addClickHandler = Sidebar.prototype.addClickHandler
|
|
9
|
+ Sidebar.prototype.addClickHandler = function (elt, ds, cells) {
|
|
10
|
+ var graph = this.editorUi.editor.graph;
|
|
11
|
+ var tol = graph.tolerance;
|
|
12
|
+ const cell = cells[0]
|
|
13
|
+ const cellValue = cell.value
|
|
14
|
+ const validate = cellValue && cellValue.nodeName === 'UserObject' && cellValue.getAttribute('componentsType') === 'charts'
|
|
15
|
+ const mouseDown = ds.mouseDown
|
|
16
|
+
|
|
17
|
+ ds.mouseDown = function (evt) {
|
|
18
|
+ if (validate) {
|
|
19
|
+ cell.value.setAttribute('id', generatorId())
|
|
20
|
+ graph.setAttributeForCell(cell, 'label', `<div class="echarts__instance" id="${ generatorId() }">${ generatorId() }</div>`)
|
|
21
|
+ }
|
|
22
|
+ mouseDown.apply(this, arguments)
|
|
23
|
+ };
|
|
24
|
+
|
|
25
|
+ const mouseUp = ds.mouseUp
|
|
26
|
+ ds.mouseUp = function () {
|
|
27
|
+ try {
|
|
28
|
+ mouseUp.apply(this, arguments)
|
|
29
|
+ } finally {
|
|
30
|
+ if (validate) {
|
|
31
|
+ const id = cell.value.id
|
|
32
|
+ const chartDom = document.getElementById(id);
|
|
33
|
+ chartDom.style.width = '400px'
|
|
34
|
+ chartDom.style.height = '400px'
|
|
35
|
+ const myChart = echarts.init(chartDom);
|
|
36
|
+ const option = {
|
|
37
|
+ xAxis: {
|
|
38
|
+ type: 'category',
|
|
39
|
+ data: [ 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun' ],
|
|
40
|
+ },
|
|
41
|
+ yAxis: {
|
|
42
|
+ type: 'value',
|
|
43
|
+ },
|
|
44
|
+ series: [
|
|
45
|
+ {
|
|
46
|
+ data: [ 150, 230, 224, 218, 135, 147, 260 ],
|
|
47
|
+ type: 'line',
|
|
48
|
+ },
|
|
49
|
+ ],
|
|
50
|
+ };
|
|
51
|
+
|
|
52
|
+ option && myChart.setOption(option);
|
|
53
|
+ }
|
|
54
|
+ }
|
|
55
|
+ // const dom = document.getElementById()
|
|
56
|
+ }
|
|
57
|
+ addClickHandler.apply(this, arguments)
|
|
58
|
+ }
|
|
59
|
+
|
|
60
|
+ const convertValueToString = this.graph.convertValueToString
|
|
61
|
+ this.graph.convertValueToString = function (cell) {
|
|
62
|
+ const cellValue = cell.value
|
|
63
|
+ const validate = cellValue && cellValue.nodeName === 'UserObject' && cellValue.getAttribute('componentsType') === 'charts'
|
|
64
|
+ if (validate) {
|
|
65
|
+ setTimeout(() => {
|
|
66
|
+ const id = cell.value.id
|
|
67
|
+ console.log(id)
|
|
68
|
+ const chartDom = document.getElementById(id);
|
|
69
|
+ chartDom.style.width = '400px'
|
|
70
|
+ chartDom.style.height = '400px'
|
|
71
|
+ const myChart = echarts.init(chartDom);
|
|
72
|
+ const option = {
|
|
73
|
+ xAxis: {
|
|
74
|
+ type: 'category',
|
|
75
|
+ data: [ 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun' ],
|
|
76
|
+ },
|
|
77
|
+ yAxis: {
|
|
78
|
+ type: 'value',
|
|
79
|
+ },
|
|
80
|
+ series: [
|
|
81
|
+ {
|
|
82
|
+ data: [ 150, 230, 224, 218, 135, 147, 260 ],
|
|
83
|
+ type: 'line',
|
|
84
|
+ },
|
|
85
|
+ ],
|
|
86
|
+ };
|
|
87
|
+
|
|
88
|
+ option && myChart.setOption(option);
|
|
89
|
+ })
|
|
90
|
+ }
|
|
91
|
+
|
|
92
|
+ return convertValueToString.apply(this, arguments)
|
|
93
|
+ }
|
|
94
|
+
|
|
95
|
+ var s = 'html=1;shadow=0;dashed=0;shape=mxgraph.atlassian.';
|
|
96
|
+ var s2 = 'html=1;shadow=0;dashed=0;fillColor=none;strokeColor=none;shape=mxgraph.bootstrap.rect;';
|
|
97
|
+ var s3 = mxConstants.STYLE_STROKEWIDTH + '=1;shadow=0;dashed=0;align=center;html=1;' + mxConstants.STYLE_SHAPE + "=mxgraph.mockup.";
|
|
98
|
+ var gn = 'mxgraph.charts';
|
|
99
|
+ var dt = 'charts ';
|
|
100
|
+ var sb = this;
|
|
101
|
+ this.setCurrentSearchEntryLibrary('charts');
|
|
102
|
+
|
|
103
|
+ const now = Date.now
|
|
104
|
+ var fns = [
|
|
105
|
+ this.addEntry('charts', mxUtils.bind(this, function () {
|
|
106
|
+ const id = generatorId()
|
|
107
|
+ var cell = new mxCell(`<div id="${ id }" class="echarts__instance"></div>`, new mxGeometry(0, 0, 400, 400), 'text;html=1;strokeColor=none;fillColor=none;align=center;verticalAlign=middle;whiteSpace=wrap;overflow=hidden;');
|
|
108
|
+ cell.setVertex(true)
|
|
109
|
+ this.graph.setAttributeForCell(cell, 'placeholders', '1');
|
|
110
|
+ this.graph.setAttributeForCell(cell, 'componentsType', 'charts');
|
|
111
|
+ cell.value.setAttribute('id', id)
|
|
112
|
+ return this.createVertexTemplateFromCells([ cell ], cell.geometry.width, cell.geometry.height, 'charts');
|
|
113
|
+ })),
|
|
114
|
+ ];
|
|
115
|
+
|
|
116
|
+ this.addPaletteFunctions('charts', '图表', false, fns);
|
|
117
|
+
|
|
118
|
+ this.setCurrentSearchEntryLibrary();
|
|
119
|
+ };
|
31
|
120
|
})();
|
|
121
|
+
|
|
122
|
+function testChartImg() {
|
|
123
|
+ return ''
|
|
124
|
+} |
|
|
\ No newline at end of file |
...
|
...
|
|