Files
@ 558eb7c5028f
Branch filter:
Location: kallithea/pylons_app/public/js/graph.js - annotation
558eb7c5028f
3.4 KiB
text/javascript
version bump to 0.8
hg app 0.8 new template.
Add yui flot and graph into summary page.
+ various tweeks and patches into look of application
hg app 0.8 new template.
Add yui flot and graph into summary page.
+ various tweeks and patches into look of application
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | a86c8de926b4 a86c8de926b4 46b7d108ea7a ab1afe7444f3 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 a86c8de926b4 a86c8de926b4 ab1afe7444f3 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 68dc70295a76 68dc70295a76 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 ab1afe7444f3 46b7d108ea7a 46b7d108ea7a a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 46b7d108ea7a a86c8de926b4 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 a86c8de926b4 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 a86c8de926b4 ab1afe7444f3 a86c8de926b4 ab1afe7444f3 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 a86c8de926b4 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 a86c8de926b4 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 a86c8de926b4 ab1afe7444f3 ab1afe7444f3 46b7d108ea7a ab1afe7444f3 ab1afe7444f3 a86c8de926b4 1dbe02063123 1dbe02063123 ab1afe7444f3 46b7d108ea7a ab1afe7444f3 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 a86c8de926b4 46b7d108ea7a ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 ab1afe7444f3 a86c8de926b4 ab1afe7444f3 a86c8de926b4 ab1afe7444f3 a86c8de926b4 a86c8de926b4 a86c8de926b4 | // branch_renderer.js - Rendering of branch DAGs on the client side
//
// Copyright 2010 Marcin Kuzminski <marcin AT python-works DOT com>
// Copyright 2008 Jesper Noehr <jesper AT noehr DOT org>
// Copyright 2008 Dirkjan Ochtman <dirkjan AT ochtman DOT nl>
// Copyright 2006 Alexander Schremmer <alex AT alexanderweb DOT de>
//
// derived from code written by Scott James Remnant <scott@ubuntu.com>
// Copyright 2005 Canonical Ltd.
//
// This software may be used and distributed according to the terms
// of the GNU General Public License, incorporated herein by reference.
var colors = [
[ 1.0, 0.0, 0.0 ],
[ 1.0, 1.0, 0.0 ],
[ 0.0, 1.0, 0.0 ],
[ 0.0, 1.0, 1.0 ],
[ 0.0, 0.0, 1.0 ],
[ 1.0, 0.0, 1.0 ],
[ 1.0, 1.0, 0.0 ],
[ 0.0, 0.0, 0.0 ]
];
function BranchRenderer() {
this.canvas = document.getElementById("graph_canvas");
if (navigator.userAgent.indexOf('MSIE') >= 0)
this.canvas = window.G_vmlCanvasManager.initElement(this.canvas);
this.ctx = this.canvas.getContext('2d');
this.ctx.strokeStyle = 'rgb(0, 0, 0)';
this.ctx.fillStyle = 'rgb(0, 0, 0)';
this.cur = [0, 0];
this.max_column = 1;
this.line_width = 2.5;
this.dot_radius = 5.5;
this.bg = [0, 4];
this.cell = [2, 0];
this.revlink = '';
this.scale = function(height) {
this.box_size = Math.floor(height/1.2);
this.cell_height = this.box_size;
this.bg_height = height;
}
this.setColor = function(color, bg, fg) {
color %= colors.length;
var red = (colors[color][0] * fg) || bg;
var green = (colors[color][1] * fg) || bg;
var blue = (colors[color][2] * fg) || bg;
red = Math.round(red * 255);
green = Math.round(green * 255);
blue = Math.round(blue * 255);
var s = 'rgb(' + red + ', ' + green + ', ' + blue + ')';
this.ctx.strokeStyle = s;
this.ctx.fillStyle = s;
}
this.render = function(data) {
var idx = 1;
var rela = document.getElementById('graph');
var pad = 160;
var scale = 22;
for (var i in data) {
this.scale(scale);
var row = document.getElementById("chg_"+idx);
var next = document.getElementById("chg_"+idx+1);
var extra = 0;
//skip this since i don't have DATE in my app
//if (next.is('.changesets-date')) {
// extra = next.outerHeight();
//}
this.cell[1] += row.clientWidth;
this.bg[1] += this.bg_height;
cur = data[i];
nodeid = cur[0];
node = cur[1];
in_l = cur[2];
for (var j in in_l) {
line = in_l[j];
start = line[0];
end = line[1];
color = line[2];
if (start > this.max_column) {
this.max_column = start;
}
if (end > this.max_column) {
this.max_column = end;
}
this.setColor(color, 0.0, 0.65);
y = row.offsetTop-rela.offsetTop+4;
x = pad-((this.cell[0] + this.box_size * start - 1) + this.bg_height-2);
this.ctx.lineWidth=this.line_width;
this.ctx.beginPath();
this.ctx.moveTo(x, y);
//i don't know why it's +1 just fixes some drawing graph.
y += row.clientHeight+1;
x = pad-((1 + this.box_size * end) + this.bg_height-2);
this.ctx.lineTo(x,y+extra,3);
this.ctx.stroke();
}
column = node[0]
color = node[1]
radius = this.dot_radius;
y = row.offsetTop-rela.offsetTop+4;
x = pad-(Math.round(this.cell[0] * scale/2 * column + radius) + 15 - (column*4));
this.ctx.beginPath();
this.setColor(color, 0.25, 0.75);
this.ctx.arc(x, y, radius, 0, Math.PI * 2, true);
this.ctx.fill();
idx++;
}
}
}
|