// JavaScript Document


/* Script by: www.jtricks.com
 * Version: 20071127
 * Latest version:
 * www.jtricks.com/javascript/navigation/fixed_menu.html
 */
fixedMenuId = 'fixeddiv';

var fixedMenu = 
{
    hasInner: typeof(window.innerWidth) == 'number',
    hasElement: document.documentElement != null
       && document.documentElement.clientWidth,

    menu: document.getElementById
        ? document.getElementById(fixedMenuId)
        : document.all
          ? document.all[fixedMenuId]
          : document.layers[fixedMenuId]
};

fixedMenu.computeShifts = function()
{
    fixedMenu.shiftX = fixedMenu.hasInner
        ? pageXOffset
        : fixedMenu.hasElement
          ? document.documentElement.scrollLeft
          : document.body.scrollLeft;
    if (fixedMenu.targetLeft > 0)
        fixedMenu.shiftX += fixedMenu.targetLeft;
    else
    {
        fixedMenu.shiftX += 
            (fixedMenu.hasElement
              ? document.documentElement.clientWidth
              : fixedMenu.hasInner
                ? window.innerWidth - 20
                : document.body.clientWidth)
            - fixedMenu.targetRight
            - fixedMenu.menu.offsetWidth;
    }

    fixedMenu.shiftY = fixedMenu.hasInner
        ? pageYOffset
        : fixedMenu.hasElement
          ? document.documentElement.scrollTop
          : document.body.scrollTop;
    if (fixedMenu.targetTop > 0)
        fixedMenu.shiftY += fixedMenu.targetTop;
    else
    {
        fixedMenu.shiftY += 
            (fixedMenu.hasElement
            ? document.documentElement.clientHeight
            : fixedMenu.hasInner
              ? window.innerHeight - 20
              : document.body.clientHeight)
            - fixedMenu.targetBottom
            - fixedMenu.menu.offsetHeight;
    }
};

fixedMenu.moveMenu = function()
{
    fixedMenu.computeShifts();

    if (fixedMenu.currentX != fixedMenu.shiftX
        || fixedMenu.currentY != fixedMenu.shiftY)
    {
        fixedMenu.currentX = fixedMenu.shiftX;
        fixedMenu.currentY = fixedMenu.shiftY;

        if (document.layers)
        {
            fixedMenu.menu.left = fixedMenu.currentX;
            fixedMenu.menu.top = fixedMenu.currentY;
        }
        else
        {
            fixedMenu.menu.style.left = fixedMenu.currentX + 'px';
            fixedMenu.menu.style.top = fixedMenu.currentY + 'px';
        }
    }

    fixedMenu.menu.style.right = '';
    fixedMenu.menu.style.bottom = '';
};

fixedMenu.floatMenu = function()
{
    fixedMenu.moveMenu();
    setTimeout('fixedMenu.floatMenu()', 20);
};

// addEvent designed by Aaron Moore
fixedMenu.addEvent = function(element, listener, handler)
{
    if(typeof element[listener] != 'function' || 
       typeof element[listener + '_num'] == 'undefined')
    {
        element[listener + '_num'] = 0;
        if (typeof element[listener] == 'function')
        {
            element[listener + 0] = element[listener];
            element[listener + '_num']++;
        }
        element[listener] = function(e)
        {
            var r = true;
            e = (e) ? e : window.event;
            for(var i = 0; i < element[listener + '_num']; i++)
                if(element[listener + i](e) === false)
                    r = false;
            return r;
        }
    }

    //if handler is not already stored, assign it
    for(var i = 0; i < element[listener + '_num']; i++)
        if(element[listener + i] == handler)
            return;
    element[listener + element[listener + '_num']] = handler;
    element[listener + '_num']++;
};

fixedMenu.supportsFixed = function()
{
    var testDiv = document.createElement("div");
    testDiv.id = "testingPositionFixed";
    testDiv.style.position = "fixed";
    testDiv.style.top = "0px";
    testDiv.style.right = "0px";
    document.body.appendChild(testDiv);
    var offset = 1;
    if (typeof testDiv.offsetTop == "number"
        && testDiv.offsetTop != null 
        && testDiv.offsetTop != "undefined")
    {
        offset = parseInt(testDiv.offsetTop);
    }
    if (offset == 0)
    {
        return true;
    }

    return false;
};

fixedMenu.init = function()
{
    if (fixedMenu.supportsFixed())
        fixedMenu.menu.style.position = "fixed";
    else
    {
        var ob = 
            document.layers 
            ? fixedMenu.menu 
            : fixedMenu.menu.style;

        fixedMenu.targetLeft = parseInt(ob.left);
        fixedMenu.targetTop = parseInt(ob.top);
        fixedMenu.targetRight = parseInt(ob.right);
        fixedMenu.targetBottom = parseInt(ob.bottom);

        if (document.layers)
        {
            menu.left = 0;
            menu.top = 0;
        }
        fixedMenu.addEvent(window, 'onscroll', fixedMenu.moveMenu);
        fixedMenu.floatMenu();
    }
};

function formatCurrency(num) {
	
	num = num.toString().replace(/\&pound;|\,/g,'');
	if(isNaN(num))
	num = "0";
	sign = (num == (num = Math.abs(num)));
	num = Math.floor(num*100+0.50000000001);
	cents = num%100;
	num = Math.floor(num/100).toString();
	if(cents<10)
	cents = "0" + cents;
	for (var i = 0; i < Math.floor((num.length-(1+i))/3); i++)
	num = num.substring(0,num.length-(4*i+3))+','+
	num.substring(num.length-(4*i+3));
	return (((sign)?'':'-') + num + '.' + cents);
}

function calcCosts(){

	var fixed_cost = 0;
	var monthly_cost = 0;
	
	for(i=0;i<document.forms['custom'].elements.length;i++){
		
		bits = document.forms['custom'].elements[i].name.split("<>");
		
		if((document.forms['custom'].elements[i].type=="checkbox")&&(document.forms['custom'].elements[i].checked==true)){
			if(bits[1]==0){
				fixed_cost += parseFloat(document.forms['custom'].elements[i].value);
			}else{
				monthly_cost += parseFloat(document.forms['custom'].elements[i].value);
			}
		}
	}
	
	document.getElementById("fixed_cost").innerHTML = "&pound;"+formatCurrency(fixed_cost);
	document.getElementById("monthly_cost").innerHTML = "&pound;"+formatCurrency(monthly_cost);

}


function calcCostsSG(num){

	var fixed_cost = 0;
	var monthly_cost = 0;
	var num_free = 0;
	
	chosen = new Array();
	
	for(i=0;i<document.forms['custom'].elements.length;i++){
		
		bits = document.forms['custom'].elements[i].name.split("<>");
		
		if((document.forms['custom'].elements[i].type=="checkbox")&&(document.forms['custom'].elements[i].checked==true)){
			if(bits[1]==0){
				if(document.forms['custom'].elements[i].disabled==false){
					chosen.push(parseFloat(document.forms['custom'].elements[i].value));
				}else{
					fixed_cost += parseFloat(document.forms['custom'].elements[i].value);
				}
			}
		}
	}
	
	chosen.sort();
	
	for(i=0;i<chosen.length;i++){
		if(i<num){
			if(chosen[i]>295){
				fixed_cost += parseFloat(chosen[i]-295);
			}
		}else{
			fixed_cost += parseFloat(chosen[i]);
		}
	}
	
	
	for(i=0;i<document.forms['custom'].elements.length;i++){
		
		bits = document.forms['custom'].elements[i].name.split("<>");
		
		if((document.forms['custom'].elements[i].type=="checkbox")&&(document.forms['custom'].elements[i].checked==true)){
			
			if(bits[1]==1){
				monthly_cost += parseFloat(document.forms['custom'].elements[i].value);
			}
		}
	}

	document.getElementById("fixed_cost").innerHTML = "&pound;"+formatCurrency(fixed_cost);
	document.getElementById("monthly_cost").innerHTML = "&pound;"+formatCurrency(monthly_cost);

}

function checkPackage(num){


	chosen = new Array();
	
	for(i=0;i<document.forms['custom'].elements.length;i++){
		
		bits = document.forms['custom'].elements[i].name.split("<>");
		
		if((document.forms['custom'].elements[i].type=="checkbox")&&(document.forms['custom'].elements[i].checked==true)){
			if(bits[1]==0){
				if(document.forms['custom'].elements[i].disabled==false){
					chosen.push(parseFloat(document.forms['custom'].elements[i].value));
				}
			}
		}
	}
	
	if(chosen.length<num){
		alert("Please make sure you have selected your "+num+" extra modules before continuing.");
		return false;
	}
	
	return true;
}


fixedMenu.addEvent(window, 'onload', fixedMenu.init);


