function disble(id,eid){
	document.getElementById(id).readOnly=true;
	document.getElementById(eid).readOnly=false;
}	


var cache = '';
var blnPageLoaded = false;

function CheckAllFields(theForm) {
	var errorMsg = '';
	if(!CheckDollarField(theForm.price))
		errorMsg += ' + valid Home Price value\n';
	
	if(document.getElementById('DPayRad2').checked){	
		if(!CheckDollarField(theForm.downpay)){
			errorMsg += ' + valid Down Payment dollar value\n';
		}		
	}	
	
	if(document.getElementById('DPayRad1').checked){
			if(!CheckFloatField(theForm.downpayperc)) {
			errorMsg += ' + valid Down Payment percent value\n';
		}
	}
	
	if(!CheckIntField(theForm.termMonths))
		errorMsg += ' + valid Loan Term in months value (integer)\n';
	if(!CheckFloatField(theForm.termYears))
		errorMsg += ' + valid Loan Term in years value\n';
	if(!CheckFloatField(theForm.intYear))
		errorMsg += ' + valid Annual Interest Rate value\n';
	if(errorMsg == '')
		return true;
	else {
		alert('Please enter:\n' + errorMsg);
		return false;
		
	}
}


function CheckFloatField(field) {
	var val = field.value;

	if(val.indexOf(".") != -1) {
		while(val.charAt(val.length-1) == "0")
			val = val.substring(0,val.length-1);
		if(val.charAt(val.length-1) == ".")
			val = val.substring(0,val.length-1);
	}

	if("" + parseFloat(val) != val)
		return false;
	else
		return true;
}


function CheckIntField(field) {
	var val = field.value;

	if(isNaN(val))
		return false;
	else {
		field.value = '' + parseInt(val)
		return true;
	}
}


function CheckDollarField(field) {
	var flt = ReadDollarField(field);

	if(isNaN(flt))
		return false;
	else {
		str = FloatToDollarString(flt);
		field.value = str;
		return true;
	}
}


function ReadDollarField(field) {
	var str = field.value;
	if(str.charAt(0) == "$")
		str = str.substring(1, str.length);

	var pos = str.lastIndexOf(",");
	while(pos != -1) {
		str = str.substring(0,pos) + str.substring(pos+1, str.length);
		pos = str.lastIndexOf(",", pos);
	}

	return parseFloat(str);
}


function FloatToDollarString(flt) {

	var str = "" + Math.round(flt)

	pos = str.length;
	pos -= 4;
	while(pos >= 0) {
		str = str.substring(0,pos+1) + "," + str.substring(pos+1, str.length);
		pos -= 3;
	}

	return str;
}


function recalcTermMonths(frm) {
	var tYr = parseFloat(frm.termYears.value);
	var tMon = Math.round(tYr * 12.0);
	tYr = parseFloat(tMon) / 12.0;
	frm.termYears.value = "" + tYr;
	frm.termMonths.value = "" + tMon;
}


function recalcTermYears(frm) {
	var tMon = parseInt(frm.termMonths.value);
	var tYr = parseFloat(tMon) / 12.0;
	frm.termYears.value = "" + tYr;
	frm.termMonths.value = "" + tMon;
}


function RecalcMonthlyPay(frm) {
	var Principle  = ReadDollarField(frm.price) - ReadDollarField(frm.downpay);
	var AnnualInt  = parseFloat(frm.intYear.value);
	var MonthlyInt = AnnualInt / (12.0 * 100.0);
	var LenMonths  = parseInt(frm.termMonths.value);

	if(MonthlyInt == 0)
		var MonthlyPay = Principle / LenMonths;
	else
		var MonthlyPay = Principle * ( MonthlyInt / ( 1 - Math.pow((1 + MonthlyInt), -LenMonths) ) );
	MonthlyPay = Math.round(MonthlyPay * 100) / 100;

	if(FloatToDollarString(MonthlyPay)=='NaN'){
		frm.payMonth.value = '';
	}
	else {
		frm.payMonth.value = FloatToDollarString(MonthlyPay);
	}
}


function RecalcDownPay(frm) {
	var AnnualInt  = parseFloat(frm.intYear.value);
	var MonthlyInt = AnnualInt / (12.0 * 100.0);
	var LenMonths  = parseInt(frm.termMonths.value);
	var MonthlyPay = ReadDollarField(frm.payMonth);
	var Principle  = ReadDollarField(frm.price) - ReadDollarField(frm.downpay);
	var OldDownPay = ReadDollarField(frm.downpay);
	var EffPrinciple

	if(MonthlyInt == 0)
		EffPrinciple = MonthlyPay * LenMonths;
	else
		EffPrinciple = MonthlyPay * ((1 - Math.pow((1 + MonthlyInt), -LenMonths)) / MonthlyInt);

	var NewDownPay = OldDownPay + (Principle - EffPrinciple);
	frm.downpay.value = "" + NewDownPay;
	CheckDollarField(frm.downpay);

	RecalcDownPayPerc(frm);
	RecalcMonthlyPay(frm);
}


function RecalcDownPayPerc(frm) {
	var HomePrice  = ReadDollarField(frm.price);
	var DownPay = ReadDollarField(frm.downpay);
	var DownPayPerc = 100 * DownPay / HomePrice;

	if(DownPayPerc >= 0  &&  DownPayPerc <= 100) {
		var DownPayPercStr = "" + DownPayPerc;

		var pos = DownPayPercStr.indexOf(".");
		if(DownPayPercStr.length > pos + 4)
			DownPayPercStr = DownPayPercStr.substring(0,pos+4);

		frm.downpayperc.value = DownPayPercStr;
	}
	else if(DownPayPerc < 0) {
		frm.downpayperc.value = "0";
		RecalcDownPayAmount(frm);
	}
	else {
		frm.downpayperc.value = "100";
		RecalcDownPayAmount(frm);
	}
}


function RecalcDownPayAmount(frm) {
	var HomePrice  = ReadDollarField(frm.price);
	var DownPayPerc = parseFloat(frm.downpayperc.value);
	if(DownPayPerc < 0) {
		frm.downpayperc.value = "0";
		RecalcDownPayAmount(frm);
	}
	else if(DownPayPerc > 100) {
		frm.downpayperc.value = "100";
		RecalcDownPayAmount(frm);
	}
	else {
		var DownPay = HomePrice * DownPayPerc / 100;
		DownPay = FloatToDollarString(DownPay);
		frm.downpay.value = "" + DownPay;
	}
}

function MM_openBrWindow(theURL,winName,features) { //v2.0
  window.open(theURL,winName,features);
}

function MM_popupMsg(msg) { //v1.0
  alert(msg);
}