##// END OF EJS Templates
Redraw revision graph on window resize (#10206)....
Redraw revision graph on window resize (#10206). git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@8866 e93f8b46-1217-0410-a6f0-8f06a7374b81

File last commit:

r8746:c5317a14ac06
r8746:c5317a14ac06
Show More
revision_graph.js
104 lines | 3.6 KiB | application/javascript | JavascriptLexer
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 var revisionGraph = null;
Toshi MARUYAMA
scm: git: mercurial: add a new feature of revision graph (#5501)...
r7605
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 function drawRevisionGraph(holder, commits_hash, graph_space) {
Etienne Massip
Revision graph code cleanup....
r8653
Etienne Massip
Integrated revision graph into scmid column....
r8730 var XSTEP = 20,
CIRCLE_INROW_OFFSET = 10;
Etienne Massip
Revision graph code cleanup....
r8653
var commits_by_scmid = $H(commits_hash),
commits = commits_by_scmid.values();
Etienne Massip
Integrated revision graph into scmid column....
r8730 var max_rdmid = commits.length - 1;
var commit_table_rows = $$('table.changesets tr.changeset');
Etienne Massip
Revision graph code cleanup....
r8653
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 // create graph
if(revisionGraph != null)
revisionGraph.clear();
else
revisionGraph = Raphael(holder);
var top = revisionGraph.set();
Etienne Massip
Integrated revision graph into scmid column....
r8730 // init dimensions
var graph_offset = $(holder).getLayout().get('top'),
graph_width = (graph_space + 1) * XSTEP,
graph_height = commit_table_rows[max_rdmid].getLayout().get('top') + commit_table_rows[max_rdmid].getLayout().get('height') - graph_offset;
Etienne Massip
Revision graph code cleanup....
r8653
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 revisionGraph.setSize(graph_width, graph_height);
Etienne Massip
Revision graph code cleanup....
r8653
// init colors
Etienne Massip
Integrated revision graph into scmid column....
r8730 var colors = [];
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 Raphael.getColor.reset();
for (var k = 0; k <= graph_space; k++) {
Etienne Massip
Revision graph code cleanup....
r8653 colors.push(Raphael.getColor());
Toshi MARUYAMA
scm: git: mercurial: add a new feature of revision graph (#5501)...
r7605 }
Etienne Massip
Revision graph code cleanup....
r8653
var parent_commit;
var x, y, parent_x, parent_y;
var path, longrefs, shortrefs, label, labelBBox;
commits.each(function(commit) {
Etienne Massip
Integrated revision graph into scmid column....
r8730 y = commit_table_rows[max_rdmid - commit.rdmid].getLayout().get('top') - graph_offset + CIRCLE_INROW_OFFSET;
x = XSTEP / 2 + XSTEP * commit.space;
Etienne Massip
Revision graph code cleanup....
r8653
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 revisionGraph.circle(x, y, 3).attr({fill: colors[commit.space], stroke: 'none'});
Etienne Massip
Revision graph code cleanup....
r8653
// title
if (commit.refs != null && commit.refs != '') {
longrefs = commit.refs;
shortrefs = longrefs.length > 15 ? longrefs.substr(0, 13) + '...' : longrefs;
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 label = revisionGraph.text(x + 5, y + 5, shortrefs)
Etienne Massip
Revision graph code cleanup....
r8653 .attr({
font: '12px Fontin-Sans, Arial',
fill: '#666',
title: longrefs,
cursor: 'pointer',
rotation: '0'});
labelBBox = label.getBBox();
label.translate(labelBBox.width / 2, -labelBBox.height / 3);
}
// paths to parents
commit.parent_scmids.each(function(parent_scmid) {
parent_commit = commits_by_scmid.get(parent_scmid);
if (parent_commit) {
Etienne Massip
Integrated revision graph into scmid column....
r8730 parent_y = commit_table_rows[max_rdmid - parent_commit.rdmid].getLayout().get('top') - graph_offset + CIRCLE_INROW_OFFSET;
parent_x = XSTEP / 2 + XSTEP * parent_commit.space;
Etienne Massip
Revision graph code cleanup....
r8653
if (parent_commit.space == commit.space) {
// vertical path
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 path = revisionGraph.path([
Etienne Massip
Revision graph code cleanup....
r8653 'M', x, y,
'V', parent_y]);
Toshi MARUYAMA
scm: git: mercurial: add a new feature of revision graph (#5501)...
r7605 } else {
Etienne Massip
Revision graph code cleanup....
r8653 // path to a commit in a different branch (Bezier curve)
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 path = revisionGraph.path([
Etienne Massip
Revision graph code cleanup....
r8653 'M', x, y,
'C', x, y, x, y + (parent_y - y) / 2, x + (parent_x - x) / 2, y + (parent_y - y) / 2,
'C', x + (parent_x - x) / 2, y + (parent_y - y) / 2, parent_x, parent_y-(parent_y-y)/2, parent_x, parent_y]);
Toshi MARUYAMA
scm: git: mercurial: add a new feature of revision graph (#5501)...
r7605 }
} else {
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 // vertical path ending at the bottom of the revisionGraph
path = revisionGraph.path([
Etienne Massip
Revision graph code cleanup....
r8653 'M', x, y,
'V', graph_height]);
Toshi MARUYAMA
scm: git: mercurial: add a new feature of revision graph (#5501)...
r7605 }
Etienne Massip
Revision graph code cleanup....
r8653 path.attr({stroke: colors[commit.space], "stroke-width": 1.5});
});
Toshi MARUYAMA
scm: git: mercurial: add a new feature of revision graph (#5501)...
r7605
Etienne Massip
Redraw revision graph on window resize (#10206)....
r8746 top.push(revisionGraph.circle(x, y, 10)
Etienne Massip
Revision graph code cleanup....
r8653 .attr({
fill: '#000',
opacity: 0,
cursor: 'pointer',
href: commit.href})
.hover(function () {}, function () {}));
});
Toshi MARUYAMA
scm: git: mercurial: add a new feature of revision graph (#5501)...
r7605
Etienne Massip
Revision graph code cleanup....
r8653 top.toFront();
Toshi MARUYAMA
scm: git: mercurial: add a new feature of revision graph (#5501)...
r7605 };