






            

var efa_default = 81;
var efa_increment = 10;
var efa_bigger = ['',
    '<div class="font_plus">+</div>',
    'Schrift gr&ouml;sser stellen',
    'link_no',
    '',
    '',
    '9',
    '',
    '',
    '',
    ' '
    ]
var efa_smaller = ['',
    '<div class="font_minus">-</div>',
    'Schrift kleiner stellen',
    'link_no',
    '',
    '',
    '9',
    '',
    '',
    '',
    '' + ''
    ]
function Efa_Fontsize(increment,bigger,smaller,def) {
    this.w3c = (document.getElementById);
    this.ms = (document.all);
    this.userAgent = navigator.userAgent.toLowerCase();
    this.isMacIE = ((this.userAgent.indexOf('msie') != -1) && (this.userAgent.indexOf('mac') != -1) && (this.userAgent.indexOf('opera') == -1));
    this.isOldOpfake = ((this.userAgent.indexOf('opera') != -1)&&(parseFloat(this.userAgent.substr(this.userAgent.indexOf('opera')+5)) <= 7));
    this.isOldOpreal = ((this.userAgent.indexOf('opera') != -1)&&(parseFloat(this.userAgent.substr(this.userAgent.indexOf('opera')+6)) <= 7));
    if ((this.w3c || this.ms) && !this.isOldOpfake && !this.isMacIE && !this.isOldOpreal) {
        this.name = "efa_fontSize";
        this.cookieName = 'efaSize';
        this.increment = increment;
        this.def = def;
        this.defPx = Math.round(16*(def/100));
        this.base = 1;
        this.pref = this.getPref();
        this.testHTML = '<div id="efaTest" style="position:absolute;visibility:hidden;line-height:1em;">&nbsp;</div>';
        this.biggerLink = this.getLinkHtml(1,bigger);
        this.smallerLink = this.getLinkHtml(-1,smaller);
    } else {
        this.biggerLink = '';
        this.smallerLink = '';
        this.efaInit = new Function('return true;');
    }
    this.allLinks = this.biggerLink + this.smallerLink;
}
Efa_Fontsize.prototype.efaInit = function() {
        document.writeln(this.testHTML);
        this.body = (this.w3c)?document.getElementsByTagName('body')[0].style:document.all.tags('body')[0].style;
        this.efaTest = (this.w3c)?document.getElementById('efaTest'):document.all['efaTest'];
        var h = (this.efaTest.clientHeight)?parseInt(this.efaTest.clientHeight):(this.efaTest.offsetHeight)?parseInt(this.efaTest.offsetHeight):999;
        if (h < this.defPx) this.base = this.defPx/h;
        this.body.fontSize = Math.round(this.pref*this.base) + '%';
}
Efa_Fontsize.prototype.getLinkHtml = function(direction,properties) {
    var html = properties[0] + '<a href="#" onclick="efa_fontSize.setSize(' + direction + '); return false;"';
    html += (properties[2])?'title="' + properties[2] + '"':'';
    html += (properties[3])?'class="' + properties[3] + '"':'';
    html += (properties[4])?'id="' + properties[4] + '"':'';
    html += (properties[5])?'name="' + properties[5] + '"':'';
    html += (properties[6])?'accesskey="' + properties[6] + '"':'';
    html += (properties[7])?'onmouseover="' + properties[7] + '"':'';
    html += (properties[8])?'onmouseout="' + properties[8] + '"':'';
    html += (properties[9])?'onfocus="' + properties[9] + '"':'';
    return html += '>'+ properties[1] + '<' + '/a>' + properties[10];
}
Efa_Fontsize.prototype.getPref = function() {
    var pref = this.getCookie(this.cookieName);
    if (pref) return parseInt(pref);
    else return this.def;
}
Efa_Fontsize.prototype.setSize = function(direction) {
    this.pref = (direction)?this.pref+(direction*this.increment):this.def;
    this.setCookie(this.cookieName,this.pref);
    if(this.pref <= 81) /*81*/
    {this.pref = 81;} /*81*/
    
    if(this.pref >= 300) /*253*/
    {this.pref = 300;} /*253*/
    
    this.body.fontSize = Math.round(this.pref*this.base) + '%';
}
Efa_Fontsize.prototype.getCookie = function(cookieName) {
    var cookie = cookieManager.getCookie(cookieName);
    return (cookie)?cookie:false;
}
Efa_Fontsize.prototype.setCookie = function(cookieName,cookieValue) {
    return cookieManager.setCookie(cookieName,cookieValue);
}
var  efa_fontSize = new Efa_Fontsize(efa_increment,efa_bigger,efa_smaller,efa_default);
