//
// BOOKING FUNCTIONS
// Author: Claus Jul Larsen
// Company: Linkfactory A/S
//

/* This script is Copyright (c) Paul McFedries and
Logophilia Limited (http://www.mcfedries.com/).
Permission is granted to use this script as long as
this Copyright notice remains in place.*/

function round_decimals(original_number, decimals) {
	var result1 = original_number * Math.pow(10, decimals)
	var result2 = Math.round(result1)
	var result3 = result2 / Math.pow(10, decimals)
	return pad_with_zeros(result3, decimals)
}

function pad_with_zeros(rounded_value, decimal_places) {

	// Convert the number to a string
	var value_string = rounded_value.toString()

	// Locate the decimal point
	var decimal_location = value_string.indexOf(".")

	// Is there a decimal point?
	if (decimal_location == -1) {

		// If no, then all decimal places will be padded with 0s
		decimal_part_length = 0

		// If decimal_places is greater than zero, tack on a decimal point
		value_string += decimal_places > 0 ? "," : ""
	}
	else {

		// If yes, then only the extra decimal places will be padded with 0s
		decimal_part_length = value_string.length - decimal_location - 1
	}

	// Calculate the number of decimal places that need to be padded with 0s
	var pad_total = decimal_places - decimal_part_length

	if (pad_total > 0) {

		// Pad the string with 0s
		for (var counter = 1; counter <= pad_total; counter++)
		value_string += "0"
	}
	return value_string
}

function ClearInvalidChar(string) {
	for (var i=0, output='', valid="1234567890,"; i<string.length; i++)
	if (valid.indexOf(string.charAt(i)) != -1)
	output += string.charAt(i)
	return output;
}

function getElementsByAttribute(oElm, strTagName, strAttributeName, strAttributeValue){
	var arrElements = (strTagName == "*" && oElm.all)? oElm.all : oElm.getElementsByTagName(strTagName);
	var arrReturnElements = new Array();
	var oAttributeValue = (typeof strAttributeValue != "undefined")? new RegExp("(^|\\s)" + strAttributeValue + "(\\s|$)", "i") : null;
	var oCurrent;
	var oAttribute;
	for(var i=0; i<arrElements.length; i++){
		oCurrent = arrElements[i];
		oAttribute = oCurrent.getAttribute && oCurrent.getAttribute(strAttributeName);
		if(typeof oAttribute == "string" && oAttribute.length > 0){
			if(typeof strAttributeValue == "undefined" || (oAttributeValue && oAttributeValue.test(oAttribute))){
				arrReturnElements.push(oCurrent);
			}
		}
	}
	return arrReturnElements;
}

function Calc(form,value,field) {
	
	var startrow = 1;

	if (value != null) {
		var formattedValue = formatToRaw(value);
		if (formattedValue.toString().length >= 6) {
			formattedValue = parseInt(formattedValue.toString().substring(0,6));
			document.getElementById(field).value = formattedValue;
		}
	}

	var total_unpaid = 0.00;
	var total_payment = 0.00;

	for (i = 1; i <= 1000; i++) {

		var unpaid = document.getElementById(prefixId + '_unpaid_' + i);
		var payment = document.getElementById(prefixId + '_payment_' + i);

		if (unpaid && payment) {
			if (formatToRaw(unpaid.value) && !isNaN(formatToRaw(unpaid.value))) {
				total_unpaid = total_unpaid + parseFloat(formatToRaw(unpaid.value));
			}

			if (formatToRaw(payment.value) && !isNaN(formatToRaw(payment.value))) {
				total_payment = total_payment + parseFloat(formatToRaw(payment.value));
			}
		} else {
			break;
		}
	}

	document.getElementById(prefixId + '_total_unpaid').innerHTML = formatCurrency(total_unpaid);
	document.getElementById(prefixId + '_total_payment').innerHTML = formatCurrency(total_payment);
	document.getElementById(prefixId + '[unpaid_transfer]').value = total_unpaid;
	document.getElementById(prefixId + '[payment_transfer]').value = total_payment;
	//alert(formattedValue);
	if (!isNaN(formattedValue) && formattedValue != 0) {
		formattedValue = parseFloat(formattedValue);
		return formatCurrency(formattedValue);
	} else {
		return '';
	}
}

function formatToRaw(num) {
	num = ClearInvalidChar(num);
	num = num.toString();
	num = num.replace('.','');
	num = num.replace(',','.');
	//num = num.replace('@',',');
	return parseFloat(num);
}

function formatCurrency(num) {
	num = num.toString().replace(/\$|\,/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);
	return (((sign)?'':'-') + num);
}

function addRow() {

	if (rows <= 9) {
		document.getElementById(prefixId + '_row_' + rows).className = 'text';

		rows++;

		var nextTabIndex = (rows*2)+1;

		var row = document.getElementById('table').insertRow(rows+1);


		var cell1 = row.insertCell(0);
		cell1.className = 'text2';
		cell1.id = prefixId + '_row_' + rows;
		var cell2 = row.insertCell(1);
		cell2.className = '';
		var cell3 = row.insertCell(2);
		cell3.className = '';

		cell1.innerHTML = 'Kontokort/forbrugslån:';
		cell2.innerHTML = '<input style="text-align:right" class="txtfelt" type="text" name="' + prefixId + '[unpaid_' + rows + ']" id="' + prefixId + '_unpaid_' + rows + '" tabindex="' + nextTabIndex + '" onblur="this.value=Calc(document.amounts,this.value,\'' + prefixId + '_unpaid_' + rows + '\')">';
		cell3.innerHTML = '<input style="text-align:right" class="txtfelt2" type="text" name="' + prefixId + '[payment_' + rows + ']" id="' + prefixId + '_payment_' + rows + '" tabindex="' + (nextTabIndex+1) + '" onblur="this.value=Calc(document.amounts,this.value,\''+prefixId+'_payment_'+rows+'\')">';
	}
}

function ValidateFields(obj) {

	var payment = parseFloat(document.getElementById(prefixId + '[payment_transfer]').value);
	var unpaid = parseFloat(document.getElementById(prefixId + '[unpaid_transfer]').value);

	var minLoan = obj.amount_min.value;
	var maxLoan = obj.amount_max.value;

	if (!payment || !unpaid) {
		alert('Udfyld venligst mindst en række');
		return false;
	}

	if (unpaid < minLoan) {
		alert('Din gæld skal være på mindst ' + number_format(minLoan) + ' kr.');
		return false;
	}

	if (unpaid > maxLoan) {
		alert('Din gæld må højst være på ' + number_format(maxLoan) + ' kr.');
		return false;
	}

	for (i = 1; i <= rows; i++) {

		var unpaid = document.getElementById(prefixId + '_unpaid_' + i);
		var payment = document.getElementById(prefixId + '_payment_' + i)

		if (unpaid && payment) {
			if ((unpaid.value > 0 && payment.value == '') || (unpaid.value == '' && payment.value > 0)) {
				alert('Både restgæld og ydelse skal være udfyldt.');
				return false;
			}
		}

	}

	var unpaid = parseFloat(document.getElementById(prefixId + '_total_unpaid').innerHTML.replace(".","").replace(",","."));
	var payment = parseFloat(document.getElementById(prefixId + '_total_payment').innerHTML.replace(".","").replace(",","."));

	if (unpaid < payment) {
		alert("Ydelsen kan ikke være større end restgælden");
		return false;
	}

	var cookieString = new Array();
	for (i = 1; i <= rows; i++) {

		var unpaid = document.getElementById(prefixId + '_unpaid_' + i);
		var payment = document.getElementById(prefixId + '_payment_' + i);

		if (unpaid && payment) {
			if (unpaid.value > 0 && payment.value > 0) {
				cookieString.push(formatToRaw(unpaid.value) + '#' + formatToRaw(payment.value));
			}
		}
	}

	if (cookieString.length > 0) {
		var toCookie = cookieString.join('|');
		Set_Cookie('CollectionLoanValues',toCookie,null,'/');
		Set_Cookie('CollectionLoanRows',rows,null,'/');
	} else {
		Delete_Cookie('CollectionLoanValues');
		Delete_Cookie('CollectionLoanRows');
	}
	return true;
}

function deleteAndRedirect(url) {
	Delete_Cookie('CollectionLoanValues','/');
	Delete_Cookie('CollectionLoanRows','/');
	document.location.href = url;
	
}

function gotoForm(amount,term,payment,restdebt,type) {

	var obj = document.forms['redirect_request'];
	obj.amount.value = amount;
	obj.term.value = term;
	obj.payment.value = payment;
	obj.ws_type.value = type;
	obj.restdebt.value = restdebt;
	obj.submit();
}

function number_format(number) {
	str = number.toString();
	i = str.indexOf(",");
	if (i<1) {
		i=str.length;
	}
	while (i>3) {
		i-=3;
		j = str.charAt(i-1);
		if (j>="0" && j<="9") {
			str = str.substr(0,i) + "." + str.substr(i);
		}
	}

	return str;
}

function clearCookie() {
	Delete_Cookie("CollectionLoanValues");
	Delete_Cookie("CollectionLoanRows");
}

/*
Script Name: Javascript Cookie Script
Author: Public Domain, with some modifications
Script Source URI: http://techpatterns.com/downloads/javascript_cookies.php
Version 1.1.1
Last Update: 4 October 2007

Changes:
1.1.1 fixes a problem with Get_Cookie that did not correctly handle case
where cookie is initialized but it has no "=" and thus no value, the 
Get_Cookie function generates a NULL exception. This was pointed out by olivier, thanks

1.1.0 fixes a problem with Get_Cookie that did not correctly handle
cases where multiple cookies might test as the same, like: site1, site

This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  
*/

// this fixes an issue with the old method, ambiguous values 
// with this test document.cookie.indexOf( name + "=" );

// To use, simple do: Get_Cookie('cookie_name'); 
// replace cookie_name with the real cookie name, '' are required
function Get_Cookie( check_name ) {
	// first we'll split this cookie up into name/value pairs
	// note: document.cookie only returns name=value, not the other components
	var a_all_cookies = document.cookie.split( ';' );
	var a_temp_cookie = '';
	var cookie_name = '';
	var cookie_value = '';
	var b_cookie_found = false; // set boolean t/f default f
	
	for ( i = 0; i < a_all_cookies.length; i++ )
	{
		// now we'll split apart each name=value pair
		a_temp_cookie = a_all_cookies[i].split( '=' );
		
		
		// and trim left/right whitespace while we're at it
		cookie_name = a_temp_cookie[0].replace(/^\s+|\s+$/g, '');
	
		// if the extracted name matches passed check_name
		if ( cookie_name == check_name )
		{
			b_cookie_found = true;
			// we need to handle case where cookie has no value but exists (no = sign, that is):
			if ( a_temp_cookie.length > 1 )
			{
				cookie_value = unescape( a_temp_cookie[1].replace(/^\s+|\s+$/g, '') );
			}
			// note that in cases where cookie is initialized but no value, null is returned
			return cookie_value;
			break;
		}
		a_temp_cookie = null;
		cookie_name = '';
	}
	if ( !b_cookie_found ) 
	{
		return null;
	}
}

/*
only the first 2 parameters are required, the cookie name, the cookie
value. Cookie time is in milliseconds, so the below expires will make the 
number you pass in the Set_Cookie function call the number of days the cookie
lasts, if you want it to be hours or minutes, just get rid of 24 and 60.

Generally you don't need to worry about domain, path or secure for most applications
so unless you need that, leave those parameters blank in the function call.
*/
function Set_Cookie( name, value, expires, path, domain, secure ) {
	// set time, it's in milliseconds
	var today = new Date();
	today.setTime( today.getTime() );
	// if the expires variable is set, make the correct expires time, the
	// current script below will set it for x number of days, to make it
	// for hours, delete * 24, for minutes, delete * 60 * 24
	if ( expires )
	{
		expires = expires * 1000 * 60 * 60 * 24;
	}
	//alert( 'today ' + today.toGMTString() );// this is for testing purpose only
	var expires_date = new Date( today.getTime() + (expires) );
	// alert('expires ' + expires_date.toGMTString());// this is for testing purposes only

	document.cookie = name + "=" +escape( value ) +
		( ( expires ) ? ";expires=" + expires_date.toGMTString() : "" ) + //expires.toGMTString()
		( ( path ) ? ";path=" + path : "" ) + 
		( ( domain ) ? ";domain=" + domain : "" ) +
		( ( secure ) ? ";secure" : "" );
}

// this deletes the cookie when called
function Delete_Cookie( name, path, domain ) {
	if ( Get_Cookie( name ) ) { document.cookie = name + "=" +
			( ( path ) ? ";path=" + path : "") +
			( ( domain ) ? ";domain=" + domain : "" ) +
			";expires=Thu, 01-Jan-1970 00:00:01 GMT";
	}
}

