2008-07-28 12:31:29 +00:00
|
|
|
var SVGNS='http://www.w3.org/2000/svg',XLINKNS='http://www.w3.org/1999/xlink';
|
|
|
|
|
|
|
|
function textrotate_make_svg(el)
|
|
|
|
{
|
|
|
|
var string=el.firstChild.nodeValue;
|
2009-11-04 08:11:02 +00:00
|
|
|
|
2008-07-29 12:27:04 +00:00
|
|
|
// Add absolute-positioned string (to measure length)
|
|
|
|
var abs=document.createElement('div');
|
|
|
|
abs.appendChild(document.createTextNode(string));
|
|
|
|
abs.style.position='absolute';
|
2014-12-24 12:31:57 +13:00
|
|
|
document.body.appendChild(abs);
|
|
|
|
var textWidth=abs.offsetWidth * 1.2,textHeight=abs.offsetHeight;
|
|
|
|
document.body.removeChild(abs);
|
2008-07-28 12:31:29 +00:00
|
|
|
|
|
|
|
// Create SVG
|
|
|
|
var svg=document.createElementNS(SVGNS,'svg');
|
|
|
|
svg.setAttribute('version','1.1');
|
2008-07-29 12:27:04 +00:00
|
|
|
var width=(textHeight*9)/8;
|
2008-07-28 12:31:29 +00:00
|
|
|
svg.setAttribute('width',width);
|
2008-07-29 12:27:04 +00:00
|
|
|
svg.setAttribute('height',textWidth+20);
|
2009-11-04 08:11:02 +00:00
|
|
|
|
2008-07-29 12:27:04 +00:00
|
|
|
// Add text
|
2008-07-28 12:31:29 +00:00
|
|
|
var text=document.createElementNS(SVGNS,'text');
|
|
|
|
svg.appendChild(text);
|
2008-07-29 12:27:04 +00:00
|
|
|
text.setAttribute('x',textWidth);
|
|
|
|
text.setAttribute('y',-textHeight/4);
|
2008-07-28 12:31:29 +00:00
|
|
|
text.setAttribute('text-anchor','end');
|
|
|
|
text.setAttribute('transform','rotate(90)');
|
|
|
|
text.appendChild(document.createTextNode(string));
|
2009-11-04 08:11:02 +00:00
|
|
|
|
2008-07-28 12:31:29 +00:00
|
|
|
// Is there an icon near the text?
|
|
|
|
var icon=el.parentNode.firstChild;
|
|
|
|
if(icon.nodeName.toLowerCase()=='img') {
|
|
|
|
el.parentNode.removeChild(icon);
|
|
|
|
var image=document.createElementNS(SVGNS,'image');
|
|
|
|
var iconx=el.offsetHeight/4;
|
|
|
|
if(iconx>width-16) iconx=width-16;
|
|
|
|
image.setAttribute('x',iconx);
|
2008-07-29 12:27:04 +00:00
|
|
|
image.setAttribute('y',textWidth+4);
|
2008-07-28 12:31:29 +00:00
|
|
|
image.setAttribute('width',16);
|
|
|
|
image.setAttribute('height',16);
|
|
|
|
image.setAttributeNS(XLINKNS,'href',icon.src);
|
|
|
|
svg.appendChild(image);
|
2009-11-04 08:11:02 +00:00
|
|
|
}
|
2008-07-28 12:31:29 +00:00
|
|
|
|
|
|
|
// Replace original content with this new SVG
|
|
|
|
el.parentNode.insertBefore(svg,el);
|
|
|
|
el.parentNode.removeChild(el);
|
|
|
|
}
|
|
|
|
|
2013-05-31 14:33:59 +08:00
|
|
|
function browser_supports_svg() {
|
|
|
|
return document.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#BasicStructure", "1.1");
|
|
|
|
}
|
|
|
|
|
2008-07-28 12:31:29 +00:00
|
|
|
function textrotate_init() {
|
2013-05-31 14:33:59 +08:00
|
|
|
if (!browser_supports_svg()) {
|
|
|
|
// Feature detect, else bail.
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2012-08-06 21:20:40 +02:00
|
|
|
YUI().use('yui2-dom', function(Y) {
|
|
|
|
var elements= Y.YUI2.util.Dom.getElementsByClassName('completion-activityname', 'span');
|
2008-07-28 12:31:29 +00:00
|
|
|
for(var i=0;i<elements.length;i++)
|
|
|
|
{
|
|
|
|
var el=elements[i];
|
|
|
|
el.parentNode.parentNode.parentNode.style.verticalAlign='bottom';
|
|
|
|
textrotate_make_svg(el);
|
|
|
|
}
|
|
|
|
|
2012-08-06 21:20:40 +02:00
|
|
|
elements= Y.YUI2.util.Dom.getElementsByClassName('completion-expected', 'div');
|
2008-07-28 12:31:29 +00:00
|
|
|
for(var i=0;i<elements.length;i++)
|
2009-11-04 08:11:02 +00:00
|
|
|
{
|
2008-07-28 12:31:29 +00:00
|
|
|
var el=elements[i];
|
|
|
|
el.style.display='inline';
|
|
|
|
var parent=el.parentNode;
|
|
|
|
parent.removeChild(el);
|
|
|
|
parent.insertBefore(el,parent.firstChild);
|
|
|
|
textrotate_make_svg(el.firstChild);
|
|
|
|
}
|
2008-11-18 10:17:27 +00:00
|
|
|
|
2012-08-06 21:20:40 +02:00
|
|
|
elements= Y.YUI2.util.Dom.getElementsByClassName('rotateheaders', 'table');
|
2008-11-18 10:17:27 +00:00
|
|
|
for(var i=0;i<elements.length;i++)
|
|
|
|
{
|
|
|
|
var table=elements[i];
|
2012-08-06 21:20:40 +02:00
|
|
|
var headercells = Y.YUI2.util.Dom.getElementsByClassName('header', 'th', table);
|
2008-11-18 10:17:27 +00:00
|
|
|
for(var j=0;j<headercells.length;j++)
|
|
|
|
{
|
|
|
|
var el=headercells[j];
|
|
|
|
textrotate_make_svg(el.firstChild);
|
|
|
|
}
|
|
|
|
}
|
2012-08-06 21:20:40 +02:00
|
|
|
});
|
2008-07-28 12:31:29 +00:00
|
|
|
}
|
|
|
|
|