﻿/*javascript for Bubble Tooltips by Alessandro Fulciniti
- http://pro.html.it - http://web-graphics.com 

Modified 2009 by Josh Vadnais
-to remove href information and change 'link :' 
replacement text in title detection 
-to add an option to have the rollover above link
Modified 2011 by Josh Vadnais
-to use class names as selector
*/

function enableTooltipsClass(searchClass) {
    var els = [];
    var links = [];
    var i, h;
    if (!document.getElementById || !document.getElementsByTagName) return;
    AddCss();
    h = document.createElement("span");
    h.id = "btc";
    h.setAttribute("id", "btc");
    h.style.position = "absolute";
    document.getElementsByTagName("body")[0].appendChild(h);
    els = document.getElementsByTagName("a");
    var tcl = " " + searchClass + " ";
    for (i = 0, j = 0; i < els.length; i++) {
        var test = " " + els[i].className + " ";
        if (test.indexOf(tcl) != -1) {
            links[j++] = els[i];
        }
        //Prepare(links[i]);
    }
    for (i = 0; i < links.length; i++) {
        Prepare(links[i]);
    }
    //alert(tcl);
}

function enableTooltips(id) {
    var links, i, h;
    if (!document.getElementById || !document.getElementsByTagName) return;
    AddCss();
    h = document.createElement("span");
    h.id = "btc";
    h.setAttribute("id", "btc");
    h.style.position = "absolute";
    document.getElementsByTagName("body")[0].appendChild(h);
    if (id == null) links = document.getElementsByTagName("a");
    else links = document.getElementById(id).getElementsByTagName("a");
    for (i = 0; i < links.length; i++) {
        Prepare(links[i]);
    }
}

function Prepare(el) {
    var tooltip, t, b, s, l;
    t = el.getAttribute("title");
    if (t == null || t.length == 0) t = "ROLLOVER";
    el.removeAttribute("title");
    tooltip = CreateEl("span", "tooltip");
    s = CreateEl("span", "top");
    s.appendChild(document.createTextNode(t));
    tooltip.appendChild(s);
    b = CreateEl("b", "bottom");
    //l=el.getAttribute("href");
    //if(l.length>30) l=l.substr(0,27)+"...";
    //b.appendChild(document.createTextNode(l));
    tooltip.appendChild(b);
    setOpacity(tooltip);
    el.tooltip = tooltip;
    el.onmouseover = showTooltip;
    el.onmouseout = hideTooltip;
    el.onmousemove = Locate;
}

function showTooltip(e) {
    document.getElementById("btc").appendChild(this.tooltip);
    Locate(e);
}

function hideTooltip(e) {
    var d = document.getElementById("btc");
    if (d.childNodes.length > 0) d.removeChild(d.firstChild);
}

function setOpacity(el) {
    el.style.filter = "alpha(opacity:95)";
    el.style.KHTMLOpacity = "0.95";
    el.style.MozOpacity = "0.95";
    el.style.opacity = "0.95";
}

function CreateEl(t, c) {
    var x = document.createElement(t);
    x.className = c;
    x.style.display = "block";
    return (x);
}

function AddCss() {
    var l = CreateEl("link");
    l.setAttribute("type", "text/css");
    l.setAttribute("rel", "stylesheet");
    //l.setAttribute("href","bt.css");
    l.setAttribute("media", "screen");
    document.getElementsByTagName("head")[0].appendChild(l);
}

function Locate(e) {
    var posx = 0, posy = 0;
    if (e == null) e = window.event;
    if (e.pageX || e.pageY) {
        posx = e.pageX; posy = e.pageY;
    }
    else if (e.clientX || e.clientY) {
        if (document.documentElement.scrollTop) {
            posx = e.clientX + document.documentElement.scrollLeft;
            posy = e.clientY + document.documentElement.scrollTop;
        }
        else {
            posx = e.clientX + document.body.scrollLeft;
            posy = e.clientY + document.body.scrollTop;
        }
    }
    document.getElementById("btc").style.top = (posy + 10) + "px";
    document.getElementById("btc").style.left = (posx - 20) + "px";
}

//=================== above functions are below =======================

function enableTooltips_A(id) {
    var links, i, h;
    if (!document.getElementById || !document.getElementsByTagName) return;
    AddCss_A();
    h = document.createElement("span");
    h.id = "btc_A";
    h.setAttribute("id", "btc_A");
    h.style.position = "absolute";
    document.getElementsByTagName("body")[0].appendChild(h);
    if (id == null) links = document.getElementsByTagName("a");
    else links = document.getElementById(id).getElementsByTagName("a");
    for (i = 0; i < links.length; i++) {
        Prepare_A(links[i]);
    }
}

function Prepare_A(el) {
    var tooltip_A, t, b, s, l;
    t = el.getAttribute("title");
    if (t == null || t.length == 0) t = "ROLLOVER";
    el.removeAttribute("title");
    tooltip_A = CreateEl_A("span", "tooltip_A");
    s = CreateEl_A("span", "top");
    s.appendChild(document.createTextNode(t));
    tooltip_A.appendChild(s);
    b = CreateEl_A("b", "bottom");
    //l=el.getAttribute("href");
    //if(l.length>30) l=l.substr(0,27)+"...";
    //b.appendChild(document.createTextNode(l));
    tooltip_A.appendChild(b);
    setOpacity_A(tooltip_A);
    el.tooltip_A = tooltip_A;
    el.onmouseover = showTooltip_A;
    el.onmouseout = hideTooltip_A;
    el.onmousemove = Locate_A;
}

function showTooltip_A(e) {
    document.getElementById("btc_A").appendChild(this.tooltip_A);
    Locate_A(e);
}

function hideTooltip_A(e) {
    var d = document.getElementById("btc_A");
    if (d.childNodes.length > 0) d.removeChild(d.firstChild);
}

function setOpacity_A(el) {
    el.style.filter = "alpha(opacity:95)";
    el.style.KHTMLOpacity = "0.95";
    el.style.MozOpacity = "0.95";
    el.style.opacity = "0.95";
}

function CreateEl_A(t, c) {
    var x = document.createElement(t);
    x.className = c;
    x.style.display = "block";
    return (x);
}

function AddCss_A() {
    var l = CreateEl_A("link");
    l.setAttribute("type", "text/css");
    l.setAttribute("rel", "stylesheet");
    //l.setAttribute("href","bt.css");
    l.setAttribute("media", "screen");
    document.getElementsByTagName("head")[0].appendChild(l);
}

function Locate_A(e) {
    var posx = 0, posy = 0;
    if (e == null) e = window.event;
    if (e.pageX || e.pageY) {
        posx = e.pageX; posy = e.pageY;
    }
    else if (e.clientX || e.clientY) {
        if (document.documentElement.scrollTop) {
            posx = e.clientX + document.documentElement.scrollLeft;
            posy = e.clientY + document.documentElement.scrollTop;
        }
        else {
            posx = e.clientX + document.body.scrollLeft;
            posy = e.clientY + document.body.scrollTop;
        }
    }
    document.getElementById("btc_A").style.top = (posy - 120) + "px";
    document.getElementById("btc_A").style.left = (posx - 20) + "px";
}
