##// END OF EJS Templates
Variable declaration cleanup....
Etienne Massip -
r9051:aebaaad85ae7
parent child
Show More
@@ -1,101 +1,101
1 var revisionGraph = null;
1 var revisionGraph = null;
2
2
3 function drawRevisionGraph(holder, commits_hash, graph_space) {
3 function drawRevisionGraph(holder, commits_hash, graph_space) {
4
4
5 var XSTEP = 20,
5 var XSTEP = 20,
6 CIRCLE_INROW_OFFSET = 10;
6 CIRCLE_INROW_OFFSET = 10;
7
7
8 var commits_by_scmid = $H(commits_hash),
8 var commits_by_scmid = $H(commits_hash),
9 commits = commits_by_scmid.values();
9 commits = commits_by_scmid.values();
10
10
11 var max_rdmid = commits.length - 1;
11 var max_rdmid = commits.length - 1;
12
12
13 var commit_table_rows = $$('table.changesets tr.changeset');
13 var commit_table_rows = $$('table.changesets tr.changeset');
14
14
15 // create graph
15 // create graph
16 if(revisionGraph != null)
16 if(revisionGraph != null)
17 revisionGraph.clear();
17 revisionGraph.clear();
18 else
18 else
19 revisionGraph = Raphael(holder);
19 revisionGraph = Raphael(holder);
20
20
21 var top = revisionGraph.set();
21 var top = revisionGraph.set();
22
22
23 // init dimensions
23 // init dimensions
24 var graph_x_offset = Element.select(commit_table_rows.first(),'td').first().getLayout().get('left') - $(holder).getLayout().get('left'),
24 var graph_x_offset = Element.select(commit_table_rows.first(),'td').first().getLayout().get('left') - $(holder).getLayout().get('left'),
25 graph_y_offset = $(holder).getLayout().get('top'),
25 graph_y_offset = $(holder).getLayout().get('top'),
26 graph_right_side = graph_x_offset + (graph_space + 1) * XSTEP,
26 graph_right_side = graph_x_offset + (graph_space + 1) * XSTEP,
27 graph_bottom = commit_table_rows.last().getLayout().get('top') + commit_table_rows.last().getLayout().get('height') - graph_y_offset;
27 graph_bottom = commit_table_rows.last().getLayout().get('top') + commit_table_rows.last().getLayout().get('height') - graph_y_offset;
28
28
29 revisionGraph.setSize(graph_right_side, graph_bottom);
29 revisionGraph.setSize(graph_right_side, graph_bottom);
30
30
31 // init colors
31 // init colors
32 var colors = [];
32 var colors = [];
33 Raphael.getColor.reset();
33 Raphael.getColor.reset();
34 for (var k = 0; k <= graph_space; k++) {
34 for (var k = 0; k <= graph_space; k++) {
35 colors.push(Raphael.getColor());
35 colors.push(Raphael.getColor());
36 }
36 }
37
37
38 var parent_commit;
38 var parent_commit;
39 var x, y, parent_x, parent_y;
39 var x, y, parent_x, parent_y;
40 var path, longrefs, shortrefs, label, labelBBox;
40 var path, title;
41
41
42 commits.each(function(commit) {
42 commits.each(function(commit) {
43
43
44 y = commit_table_rows[max_rdmid - commit.rdmid].getLayout().get('top') - graph_y_offset + CIRCLE_INROW_OFFSET;
44 y = commit_table_rows[max_rdmid - commit.rdmid].getLayout().get('top') - graph_y_offset + CIRCLE_INROW_OFFSET;
45 x = graph_x_offset + XSTEP / 2 + XSTEP * commit.space;
45 x = graph_x_offset + XSTEP / 2 + XSTEP * commit.space;
46
46
47 revisionGraph.circle(x, y, 3)
47 revisionGraph.circle(x, y, 3)
48 .attr({
48 .attr({
49 fill: colors[commit.space],
49 fill: colors[commit.space],
50 stroke: 'none',
50 stroke: 'none',
51 }).toFront();
51 }).toFront();
52
52
53 // paths to parents
53 // paths to parents
54 commit.parent_scmids.each(function(parent_scmid) {
54 commit.parent_scmids.each(function(parent_scmid) {
55 parent_commit = commits_by_scmid.get(parent_scmid);
55 parent_commit = commits_by_scmid.get(parent_scmid);
56
56
57 if (parent_commit) {
57 if (parent_commit) {
58 parent_y = commit_table_rows[max_rdmid - parent_commit.rdmid].getLayout().get('top') - graph_y_offset + CIRCLE_INROW_OFFSET;
58 parent_y = commit_table_rows[max_rdmid - parent_commit.rdmid].getLayout().get('top') - graph_y_offset + CIRCLE_INROW_OFFSET;
59 parent_x = graph_x_offset + XSTEP / 2 + XSTEP * parent_commit.space;
59 parent_x = graph_x_offset + XSTEP / 2 + XSTEP * parent_commit.space;
60
60
61 if (parent_commit.space == commit.space) {
61 if (parent_commit.space == commit.space) {
62 // vertical path
62 // vertical path
63 path = revisionGraph.path([
63 path = revisionGraph.path([
64 'M', x, y,
64 'M', x, y,
65 'V', parent_y]);
65 'V', parent_y]);
66 } else {
66 } else {
67 // path to a commit in a different branch (Bezier curve)
67 // path to a commit in a different branch (Bezier curve)
68 path = revisionGraph.path([
68 path = revisionGraph.path([
69 'M', x, y,
69 'M', x, y,
70 'C', x, y, x, y + (parent_y - y) / 2, x + (parent_x - x) / 2, y + (parent_y - y) / 2,
70 'C', x, y, x, y + (parent_y - y) / 2, x + (parent_x - x) / 2, y + (parent_y - y) / 2,
71 'C', x + (parent_x - x) / 2, y + (parent_y - y) / 2, parent_x, parent_y-(parent_y-y)/2, parent_x, parent_y]);
71 'C', x + (parent_x - x) / 2, y + (parent_y - y) / 2, parent_x, parent_y-(parent_y-y)/2, parent_x, parent_y]);
72 }
72 }
73 } else {
73 } else {
74 // vertical path ending at the bottom of the revisionGraph
74 // vertical path ending at the bottom of the revisionGraph
75 path = revisionGraph.path([
75 path = revisionGraph.path([
76 'M', x, y,
76 'M', x, y,
77 'V', graph_bottom]);
77 'V', graph_bottom]);
78 }
78 }
79 path.attr({stroke: colors[commit.space], "stroke-width": 1.5}).toBack();
79 path.attr({stroke: colors[commit.space], "stroke-width": 1.5}).toBack();
80 });
80 });
81
81
82 revision_dot_overlay = revisionGraph.circle(x, y, 10);
82 revision_dot_overlay = revisionGraph.circle(x, y, 10);
83 revision_dot_overlay
83 revision_dot_overlay
84 .attr({
84 .attr({
85 fill: '#000',
85 fill: '#000',
86 opacity: 0,
86 opacity: 0,
87 cursor: 'pointer',
87 cursor: 'pointer',
88 href: commit.href
88 href: commit.href
89 });
89 });
90
90
91 if(commit.refs != null && commit.refs.length > 0) {
91 if(commit.refs != null && commit.refs.length > 0) {
92 title = document.createElementNS(revisionGraph.canvas.namespaceURI, 'title');
92 title = document.createElementNS(revisionGraph.canvas.namespaceURI, 'title');
93 title.appendChild(document.createTextNode(commit.refs));
93 title.appendChild(document.createTextNode(commit.refs));
94 revision_dot_overlay.node.appendChild(title);
94 revision_dot_overlay.node.appendChild(title);
95 }
95 }
96
96
97 top.push(revision_dot_overlay);
97 top.push(revision_dot_overlay);
98 });
98 });
99
99
100 top.toFront();
100 top.toFront();
101 };
101 };
General Comments 0
You need to be logged in to leave comments. Login now