annotate public/javascripts/revision_graph.js @ 1621:3a510bf6a9bc

Merge from live branch
author Chris Cannam
date Fri, 13 Jul 2018 10:44:33 +0100
parents 261b3d9a4903
children
rev   line source
Chris@1115 1 var revisionGraph = null;
Chris@1115 2
Chris@1115 3 function drawRevisionGraph(holder, commits_hash, graph_space) {
Chris@1115 4 var XSTEP = 20,
Chris@1115 5 CIRCLE_INROW_OFFSET = 10;
Chris@1115 6 var commits_by_scmid = commits_hash,
Chris@1115 7 commits = $.map(commits_by_scmid, function(val,i){return val;});
Chris@1115 8 var max_rdmid = commits.length - 1;
Chris@1115 9 var commit_table_rows = $('table.changesets tr.changeset');
Chris@1115 10
Chris@1115 11 // create graph
Chris@1115 12 if(revisionGraph != null)
Chris@1115 13 revisionGraph.clear();
Chris@1115 14 else
Chris@1115 15 revisionGraph = Raphael(holder);
Chris@1115 16
Chris@1115 17 var top = revisionGraph.set();
Chris@1115 18 // init dimensions
Chris@1115 19 var graph_x_offset = commit_table_rows.first().find('td').first().position().left - $(holder).position().left,
Chris@1115 20 graph_y_offset = $(holder).position().top,
Chris@1115 21 graph_right_side = graph_x_offset + (graph_space + 1) * XSTEP,
Chris@1115 22 graph_bottom = commit_table_rows.last().position().top + commit_table_rows.last().height() - graph_y_offset;
Chris@1115 23
Chris@1115 24 revisionGraph.setSize(graph_right_side, graph_bottom);
Chris@1115 25
Chris@1115 26 // init colors
Chris@1115 27 var colors = [];
Chris@1115 28 Raphael.getColor.reset();
Chris@1115 29 for (var k = 0; k <= graph_space; k++) {
Chris@1115 30 colors.push(Raphael.getColor());
Chris@909 31 }
Chris@909 32
Chris@1115 33 var parent_commit;
Chris@1115 34 var x, y, parent_x, parent_y;
Chris@1115 35 var path, title;
Chris@1115 36 var revision_dot_overlay;
Chris@1115 37 $.each(commits, function(index, commit) {
Chris@1115 38 if (!commit.hasOwnProperty("space"))
Chris@1115 39 commit.space = 0;
Chris@909 40
Chris@1115 41 y = commit_table_rows.eq(max_rdmid - commit.rdmid).position().top - graph_y_offset + CIRCLE_INROW_OFFSET;
Chris@1115 42 x = graph_x_offset + XSTEP / 2 + XSTEP * commit.space;
Chris@1115 43 revisionGraph.circle(x, y, 3)
Chris@1115 44 .attr({
Chris@1115 45 fill: colors[commit.space],
Chris@1464 46 stroke: 'none'
Chris@1115 47 }).toFront();
Chris@1115 48 // paths to parents
Chris@1115 49 $.each(commit.parent_scmids, function(index, parent_scmid) {
Chris@1115 50 parent_commit = commits_by_scmid[parent_scmid];
Chris@1115 51 if (parent_commit) {
Chris@1115 52 if (!parent_commit.hasOwnProperty("space"))
Chris@1115 53 parent_commit.space = 0;
Chris@909 54
Chris@1115 55 parent_y = commit_table_rows.eq(max_rdmid - parent_commit.rdmid).position().top - graph_y_offset + CIRCLE_INROW_OFFSET;
Chris@1115 56 parent_x = graph_x_offset + XSTEP / 2 + XSTEP * parent_commit.space;
Chris@1115 57 if (parent_commit.space == commit.space) {
Chris@1115 58 // vertical path
Chris@1115 59 path = revisionGraph.path([
Chris@1115 60 'M', x, y,
Chris@1115 61 'V', parent_y]);
Chris@909 62 } else {
Chris@1115 63 // path to a commit in a different branch (Bezier curve)
Chris@1115 64 path = revisionGraph.path([
Chris@1115 65 'M', x, y,
Chris@1115 66 'C', x, y, x, y + (parent_y - y) / 2, x + (parent_x - x) / 2, y + (parent_y - y) / 2,
Chris@1115 67 'C', x + (parent_x - x) / 2, y + (parent_y - y) / 2, parent_x, parent_y-(parent_y-y)/2, parent_x, parent_y]);
Chris@909 68 }
Chris@909 69 } else {
Chris@1115 70 // vertical path ending at the bottom of the revisionGraph
Chris@1115 71 path = revisionGraph.path([
Chris@1115 72 'M', x, y,
Chris@1115 73 'V', graph_bottom]);
Chris@1115 74 }
Chris@1115 75 path.attr({stroke: colors[commit.space], "stroke-width": 1.5}).toBack();
Chris@1115 76 });
Chris@1115 77 revision_dot_overlay = revisionGraph.circle(x, y, 10);
Chris@1115 78 revision_dot_overlay
Chris@1115 79 .attr({
Chris@1115 80 fill: '#000',
Chris@1115 81 opacity: 0,
Chris@1115 82 cursor: 'pointer',
Chris@1115 83 href: commit.href
Chris@1115 84 });
Chris@1115 85
Chris@1115 86 if(commit.refs != null && commit.refs.length > 0) {
Chris@1115 87 title = document.createElementNS(revisionGraph.canvas.namespaceURI, 'title');
Chris@1115 88 title.appendChild(document.createTextNode(commit.refs));
Chris@1115 89 revision_dot_overlay.node.appendChild(title);
Chris@1115 90 }
Chris@1115 91 top.push(revision_dot_overlay);
Chris@1115 92 });
Chris@909 93 top.toFront();
Chris@909 94 };