var advancedSearchLoaded   = false;
var newVehicleSearchLoaded = false;
var leasingVehicleSearchLoaded = false;
var advancedSearchCarCount = 0;
var advancedSearchVanCount = 0;
var possibleVehicleTypes   = ['car', 'van', 'bike'];

var resultDisplayKeyboardHighlight = 0;
var currentISearch = '';
var totalResults   = 0;
var favouritesLimit  = 6;
var quickSearchResults = new Array();

 // Remembers the value for when moving away from the quick search and coming back
var rememberQuickVehicleSearchValue = '';

// Remembers results from quick search to show them again without ajax call
var rememberedDisplayText = '';

document.onkeydown = detectkeyPress;

$(document).ready(function() {
    // The following three lines are from css's layout.js
    // Display search form (is set to display:none to prevent fouc)
    $('#tabVehicleSearch').css('display', 'block');
    $('#tabUsedVehicleInfo').css('display', 'block');

	// Create tabs and start them working
    $("#tabVehicleSearch").tabs()
	$("#tabUsedVehicleInfo").tabs();

	// Create tabs and start them working
    $("#tabVehicleSearch").tabs();
	$("#tabNewVehicleSpec").tabs();
	$("#tabUsedVehicleInfo").tabs();
    
    collectAdvancedSearchCount();

	$('input[name=addToCompare]').change( function( event ) {
		if ( event.target.checked ) {
			if ($("input:checkbox:checked").length > 2) {
				$(this).attr('checked',false);
				alert('You may only select two cars to compare.');
				event.preventDefault();
			}else{
				addToCompare( event.target.value );
			}
		} else {
			removeFromCompare( event.target.value );
		}
	});

	// Generate Price
	priceListing();
	rememberSearchSettings();

	// Generate GUID for intellitracker.
	if( typeof itGuid === 'undefined' ){
		itGenerateGuid();
	}

	if( favouriteParams.sideNavLimit != null && favouriteParams.sideNavLimit > 0 ){
		favouritesLimit = favouriteParams.sideNavLimit;
	}
	if( favouriteParams.onLoad != null && favouriteParams.onLoad == '' ){
		showMyFavourites();
	}


	$('#layout_stockUpdates_email').click(
		function(event) {
			if ($('#layout_stockUpdates_email').val() == '- Enter Email Here -') {
				$('#layout_stockUpdates_email').val('');
			}
		}
	);


	/**
	* @ desc This is the pop up dialog box for Retrieving Favourites
	*/
	$("#dialogRetrieveFavourites").dialog({
		autoOpen: false,
		width: 600,
		modal: true,
		resizable: false,
		buttons: {
			"submit":{
			  text:'Submit',
			  className:'btnSubmit',
			  title:'Submit',
			  click:function(){retrieveFavourites();}
			},
			"cancel":{
			  text:'Cancel',
			  className:'btnCancel',
			  title:'Cancel',
			  click:function(){$(this).dialog('close');}
			}
		},
		close: function() {
		}
	});


	/**
	* @ desc This is the pop up dialog box for Saving Favourites
	*/
	$("#dialogSaveFavourites").dialog({
		autoOpen: false,
		width: 600,
		modal: true,
		resizable: false,
		buttons: {
			"submit":{
			  text:'Submit',
			  className:'btnSubmit',
			  title:'Submit',
			  click:function(){saveFavourites();}
			},
			"cancel":{
			  text:'Cancel',
			  className:'btnCancel',
			  title:'Cancel',
			  click:function(){$(this).dialog('close');}
			}
		},
		close: function() {
		}
	});
    
    /**
	* @ desc This is the pop up dialog box for Value My Vehicle
	*/
	$("#dialogCustomValueMyVehicle").dialog({
		autoOpen: false,
		width: 600,
		modal: true,
		resizable: false,
		draggable: true,
		buttons: {
			"submit":{
			  text:'Submit',
			  className:'btnSubmit',
			  title:'Submit',
			  click:function(){submitCustomForm('CustomValueMyVehicle');}
			},
			"cancel":{
			  text:'Cancel',
			  className:'btnCancel',
			  title:'Cancel',
			  click:function(){$(this).dialog('close');}
			}
		},
		close: function() {
		}
	});

	/**
	 * @ desc This is the pop up dialog box for CMS Share With a Friend
	 */
	$("#dialogCustomShareWithFriend").dialog({
		autoOpen: false,
		width: 600,
		modal: true,
		resizable: false,
		draggable: true,
		buttons: {
			"submit":{
				text:'Submit',
				className:'btnSubmit',
				title:'Submit',
				click:function(){submitCustomForm('CustomShareWithFriend');}
			},
			"cancel":{
				text:'Cancel',
				className:'btnCancel',
				title:'Cancel',
				click:function(){$(this).dialog('close');}
			}
		},
		close: function() {
		}
	});

	/**
	 * Looks for any form title fields and populates the title select box
	 */
	$('.prePopulateTitleList').each(function(){

		var thisSelection = '#' + this.id;
		
		// Remove all options
		$(thisSelection).removeOption(/./).addOption('', '- Select Title -');

		// Add Options
		$.each(selectTitleList, function(i,item){
			$(thisSelection).addOption(item.title, item.title);
		});

		$(thisSelection).attr( "selectedIndex", 0);
	});


	/**
	* Looks for any form country fields and populates the country select box
	*/
	$('.prePopulateCountryList').each(function(){

		var thisSelection = '#' + this.id;
		// Remove all options
		$( thisSelection ).removeOption(/./).addOption('', '- Select Country -').addOption('United Kingdom', 'United Kingdom');

		// Add Options
		$.each(selectCountryList, function(i,item){
			$( thisSelection ).addOption(item.country, item.country);
		});
		$( thisSelection ).attr( "selectedIndex", 0);
	});


	/**
	* Looks for any form county fields and populates the county select box
	*/
	$('.prePopulateCountyList').each(function(){

		var thisSelection = '#' + this.id;
		// Remove all options
		$( thisSelection ).removeOption(/./).addOption('', '- Select County -');

		var currentCountry = '';
		var text = '';

		// Add Options
		$.each(selectCountyList, function(i,item){

			if( currentCountry != item.country ){
				if( i > 0 ){
					text += '</optgroup>';
				}
				text += '<optgroup label="' + item.country + '">';
				currentCountry = item.country;
			}
			text += '<option value="' + item.county + '">' + item.county + '</option>';
		});
		text += '</optgroup>';
		$( thisSelection ).html(text);
		$( thisSelection ).attr( "selectedIndex", 0);
	});


	/**
	* Looks for any form country field and adjusts the county fields accordingly
	*/
	$('.prePopulateCountryList').change(function(){

		// Find the formId of the form this element sits in
		var thisFormId = '#' + $( this ).get( 0 ).form.id;

		// Then adjust the county field where necessary
		if( this.options[ this.selectedIndex].value == 'United Kingdom' ){

			$( thisFormId + ' .countySelectboxField').show();
			$( thisFormId + ' .countyInputField').hide();

		}else{

			$( thisFormId + ' .countySelectboxField').hide();
			$( thisFormId + ' .countyInputField').show();
		}
	});

	$(".init-validator").validate();
    

    $('#compareSubmitButton').click(function(){
        if ($("input:checkbox:checked").length != 2) {
            alert('Please select two cars to compare.');
        }
        else{
            //var desination = window.location.hostname+'used-cars/compare';
            window.location = '../used-cars/compare'
        }
    });

	initDatePickerAnywhere();

    // For unique styling of dialog buttons

	/*$('.ui-dialog-buttonpane button').each( function () {

		var html = $(this).html();
		$(this).addClass('btn' + html);
		$(this).html('<span class="ui-button-text" title="'+html+'">' + html + '</span>');
	});

	var buttons = $('.ui-dialog-buttonpane').children('button');
	buttons.removeClass('ui-button-text-only').addClass('ui-button-text-icon').addClass('ui-button');*/

	if (typeof FB == 'object') {
		FB.Event.subscribe('edge.create',
			function(response) {
				itEvent('facebookLike', {guid : itGuid});
				itGenerateGuid();
			}
		);
	}

	if (typeof twttr == 'object') {
		twttr.events.bind('tweet', function(event) {
			if (event) {
				itEvent('tweet', {guid : itGuid});
				itGenerateGuid();
			}
		});
	}
});

function initDatePickerAnywhere() {
	// Datepicker anywhere!
	// When buttonImageOnly is enabled, buttonText specifies alt text
	var dateOptions = {
		dateFormat: 'dd/mm/yy',
		changeYear: true,
		changeMonth: true,
		showOn: "both",
		buttonImage: netdirector.baseUrl +"/local/images/iconCalendar.gif",
		buttonImageOnly: true,
		buttonText: 'Pick a date from a calendar'
	};
	$('input.datePicker').datepicker(dateOptions);

	var dateOptionsFuture = {
		minDate: +1,
		dateFormat: 'dd/mm/yy',
		showOn: "both",
		buttonImage: netdirector.baseUrl +"/local/images/iconCalendar.gif",
		buttonImageOnly: true,
		buttonText: 'Pick a date from a calendar'
	};
	$('input.datePickerFuture').datepicker(dateOptionsFuture);

	var dateOptionsPast = {
		maxDate: -1,
		changeMonth: true,
		changeYear: true,
		dateFormat: 'dd/mm/yy',
		showOn: "both",
		buttonImage: netdirector.baseUrl +"/local/images/iconCalendar.gif",
		buttonImageOnly: true,
		buttonText: 'Pick a date from a calendar'
	};
	$('input.datePickerPast').datepicker(dateOptionsPast);
}

	function populatePriceRange(){
        
        var price = $('#price_high_low').val();
        var exploded_price = price.split('-');
        
        $('#lower_price').val(exploded_price[0]);
        $('#price').val(exploded_price[1]);
        
        collectAdvancedSearchCount();
    }
/**
* @ desc This will attempt to open a dialog form via passed in ids
*/
function openDialogForm( dialogName, formName, alertBoxName ){

	if( dialogName != '' && formName != '' ){

		// Clear the form values
		clearFormElements('#' + formName);

		// Removes validation messages
		var validator = $('#' + formName).validate();
		if(validator){
			validator.resetForm();
		}

		if( alertBoxName != '' ){

			// Clear Alert Box Text
			resetTips( alertBoxName, true );
		}

		// Open the dialog box
		$('#' + dialogName ).dialog('open');

		// highlight first input
		//$('#' + dialogName + ' :input:text:first').focus();
	}
}


function displayFormCaptchaImage( formElementId ){

	var form = $(formElementId)

	if( form.length && $('div.captcha', form).length ){

		var target = '/frontend-operations/get-form-captcha-image/';

		$.getJSON(target,
		function(data){
			//If data is null, then captcha is turned off.
			if(data){
				if( data.id && $( 'input[name=sc[id]]', form ).length  ){

					$('input[name=sc[id]]', form ).val( data.id );

				}

				if( data.image && $('div.captcha div.captchaImage', form).length ){

					$('div.captcha div.captchaImage', form).html( data.image );

					if( $('div.captcha:hidden', form).length ){

						$('div.captcha', form).animate({
							opacity: 'toggle',
							height: 'toggle'
						},500);
					}
				}
			}

		});

	}
}


/**
* @ desc This will attempt to reset any options selected in the search
*/
function rememberSearchSettings(){

	if( parseInt( searchParams.isBike ) == 1 ){

		showCarSearch('bike');

	}else if( parseInt( searchParams.isVan ) == 1 ){

		showCarSearch('van');
        $('#tabUsedVans').addClass('active');

	}else{

		showCarSearch('car');
        $('#tabUsedCars').addClass('active');
	}
}


/**
* @ desc This will show/hide advanced search options
*/
function toggleAdvancedSearch( el ){

	$( el ).animate({opacity: 'toggle', height: 'toggle'}, 300);
}


/**
* @ desc This updates the dialog alert box, passes in a header, text, type of msg, and optional input to highlight
*/
function updateTips(header,text,msgType,highlightInput,alertBoxId) {

	// Clear Alert Box Text
	resetTips(alertBoxId);

	var alertBox = ( alertBoxId != null && alertBoxId != '' ) ? $('#'+alertBoxId) : $('#dialogAlertBox');

	txt = '<strong>'+header+':</strong> '+ text;
	switch( msgType ){
		case 'error':
			msg = "<p>" + txt + "</p>";
			alertBox.addClass('ui-state-error').html(msg);
		break;

		case 'highlight':
			msg = "<p>" + txt + "</p>";
			alertBox.addClass('ui-state-highlight').html(msg);
		break;

		default:
			console.log('Error: No valid message type set');
		break;
	}

	if( highlightInput != '' ){
		$('#' + highlightInput).addClass('ui-state-error');
	}

	alertBox.slideDown(200);
}


/**
* @ desc This Resets the dialog alert box
*/
function resetTips(alertBoxId, close) {

	alertBox = ( alertBoxId != null && alertBoxId != '' ) ? $('#'+alertBoxId) : $('#dialogAlertBox');
	alertBox.removeClass('ui-state-error ui-state-highlight').html('');

	if (typeof close !== 'undefined' && !close) {
		alertBox.css('display', 'none');
	}
}


/**
* @ desc This will close the dialog box
*/
function autoCloseDialog(dialogFormType){

	$( "#" + dialogFormType ).dialog('close');
}


/**
* @ desc This will empty all form elements
*/
function clearFormElements(el) {

	$(el).find(':input:not(:.noClear)').each(function() {
		switch(this.type) {
			case 'password':
			case 'select-multiple':
			case 'select-one':
			case 'text':
			case 'textarea':
				$(this).val('');
				break;
			case 'checkbox':
			case 'radio':
				this.checked = false;
		}
		$(this).removeClass('ui-state-error');
	});
}


/**
* @ desc This is a generic ajax request function
*/
function ndCollector( target, params, successFunction, errorFunction ){

	$.ajax({
		url: target,
		dataType: 'json',
		data: params,
		success: successFunction,
		error: errorFunction
	});
}


/**
* @ desc This will collect Available Models
*/
function collectAvailableModels(selectedId, nonUser){

	nonUser    = ( nonUser != null && nonUser == true )? true : false;

	var isVan  = $('#is_van').val();
	var isBike = $('#is_bike').val();

	var marqueId = $("#auto_marque_detail_id").val();
	var modelId  = $("#auto_model_detail_id");

	modelId.attr('disabled', 'disabled');

	$.ajax({
		url: '/frontend-operations/available-model-list/',
		dataType: 'json',
		data: 'marque_id=' + marqueId + '&is_van=' + isVan + '&is_bike=' + isBike,
		success: function(data){

				// Remove all options
				modelId.removeOption(/./);

				// Add Options
				$.each(data, function(i,item){

					modelId.addOption(item.id, item.modelName);
				});

				// If previously selected..
				if( selectedId != null && selectedId > 0){

					modelId.selectOptions(selectedId);

				}else{
					// select 1st one if only one available
					var preSelect = ( data.length == 1 ) ? 1: 0;
					modelId.attr( "selectedIndex", preSelect);
				}
				modelId.removeAttr('disabled');

				if( !nonUser ){

					// Calculate vehicle count only if user has changed selection
					collectAdvancedSearchCount();
				}
            collectAdvancedSearchCount();
			},
		error: function(objRequest){

			modelId.removeAttr('disabled');
		}
	});
}

/**
* @ desc This will collect Available Models
*/
function collectAvailableLeasingModels(selectedId, nonUser){

	nonUser    = ( nonUser != null && nonUser == true )? true : false;

	var marqueId = $("#auto_leasing_marque_detail_id").val();
	var modelId  = $("#auto_leasing_model_detail_id");

	modelId.attr('disabled', 'disabled');

	$.ajax({
		url: '/frontend-operations/available-leasing-model-list/',
		dataType: 'json',
		data: 'marque_id=' + marqueId,
		success: function(data){

				// Remove all options
				modelId.removeOption(/./);

				// Add Options
				$.each(data, function(i,item){

					modelId.addOption(item.model_name, item.model_name);
				});

				// If previously selected..
				if( selectedId != null && selectedId > 0){

					modelId.selectOptions(selectedId);

				}else{
					// select 1st one if only one available
					var preSelect = ( data.length == 1 ) ? 1: 0;
					modelId.attr( "selectedIndex", preSelect);
				}
				modelId.removeAttr('disabled');

				if( !nonUser ){

					// Calculate vehicle count only if user has changed selection
					collectAdvancedSearchCount();
				}
			},
		error: function(objRequest){

			modelId.removeAttr('disabled');
		}
	});
}


/**
* @ desc This will collect All Models under a particular Make
*/
function collectAllModels(elementId, marqueId, isVan, selectedId){

	var modelId = $( elementId );
	modelId.attr('disabled', 'disabled');

	$.ajax({
		url: '/frontend-operations/all-model-list/',
		dataType: 'json',
		data: 'marque_id=' + marqueId + '&is_van=' + isVan,
		success: function(data){

				// Remove all options
				modelId.removeOption(/./).addOption('', '- Select Model -');

				// Add Options
				$.each(data, function(i,item){

					modelId.addOption(item.id, item.modelName);
				});

				// If previously selected..
				if( selectedId != null && selectedId > 0){
					modelId.selectOptions(selectedId);
				}else{
					// select 1st one if only one available
					var preSelect = ( data.length == 1 ) ? 1: 0;
					modelId.attr( "selectedIndex", preSelect);
				}
				modelId.removeAttr('disabled');
			},
		error: function(objRequest){

			modelId.removeAttr('disabled').removeOption(/./).addOption('', '- Select Model -');
		}
	});
}


/**
* @ desc This will collect All Makes under a particular Vehicle Type
*/
function collectAllMakes(elementId, isVan, selectedId){

	var marqueId = $( elementId );
	marqueId.attr('disabled', 'disabled');

	$.ajax({
		url: '/frontend-operations/all-marque-list/',
		dataType: 'json',
		data: 'is_van=' + isVan,
		success: function(data){

				// Remove all options
				marqueId.removeOption(/./).addOption('', '- Select Marque -');

				// Add Options
				$.each(data, function(i,item){

					marqueId.addOption(item.id, item.marqueName);
				});

				// If previously selected..
				if( selectedId != null && selectedId > 0){
					marqueId.selectOptions(selectedId);
				}else{
					// select 1st one if only one available
					var preSelect = ( data.length == 1 ) ? 1: 0;
					marqueId.attr( "selectedIndex", preSelect);
				}
				marqueId.removeAttr('disabled');
			},
		error: function(objRequest){

			marqueId.removeAttr('disabled').removeOption(/./).addOption('', '- Select Marque -');
		}
	});
}


/**
* @ desc This will collect New Vehicle Marque Lists
*/
function collectNewVehicleMarqueLists(){

	// Only load lists once
	if( newVehicleSearchLoaded != true ){

		// Remove all options and disable
		$('#new_car_franchise_detail_id').attr('disabled', 'disabled');
		$('#new_van_franchise_detail_id').attr('disabled', 'disabled');

		$.ajax({
			url: '/frontend-operations/new-vehicle-marque-list/',
			dataType: 'json',
			data: '',
			success: function(data){

					newVehicleSearchLoaded = true;

					// Remove loading and show default select option
					$('#new_car_franchise_detail_id').removeOption(/./).addOption('', '-  Select Make  -');
					$('#new_van_franchise_detail_id').removeOption(/./).addOption('', '-  Select Make  -');

					// Add Options
					if( data.newMarque != null ){
						$.each(data.newMarque, function(i,item){
							$("#new_car_franchise_detail_id").addOption(item.id, item.marqueName);
							$( '#new_car_franchise_detail_id option:last' ).data('url',item.franchiseUrl);
						});
					}

					if( data.newVanMarque != null ){
						$.each(data.newVanMarque, function(i,item){
							$("#new_van_franchise_detail_id").addOption(item.id, item.marqueName);
							$( '#new_van_franchise_detail_id option:last' ).data('url',item.franchiseUrl);
						});
					}

					$('#new_car_franchise_detail_id').removeAttr('disabled').attr( "selectedIndex", 0);
					$('#new_van_franchise_detail_id').removeAttr('disabled').attr( "selectedIndex", 0);
				},
			error: function(objRequest){

				$('#new_car_franchise_detail_id').removeAttr('disabled').removeOption(/./).addOption('', '-  Select Make  -');
				$('#new_van_franchise_detail_id').removeAttr('disabled').removeOption(/./).addOption('', '-  Select Make  -');
			}
		});
	}
}


/**
* @ desc This will collect New Vehicle Marque Lists
*/
function collectLeasingVehicleMarqueLists(){

	// Only load lists once
	if( leasingVehicleSearchLoaded != true ){

		// Remove all options and disable
		$('#auto_leasing_marque_detail_id').attr('disabled', 'disabled');

		$.ajax({
			url: '/frontend-operations/leasing-vehicle-marque-list/',
			dataType: 'json',
			data: '',
			success: function(data){

					newVehicleSearchLoaded = true;

					// Remove loading and show default select option
					$('#auto_leasing_marque_detail_id').removeOption(/./).addOption('', 'Select Make');

					// Add Options
					if( data.leasingMarque != null ){
						$.each(data.leasingMarque, function(i,item){
							$("#auto_leasing_marque_detail_id").addOption(item.marque_name, item.marque_name);
							$( '#auto_leasing_marque_detail_id option:last' ).data('url',item.franchiseUrl);
						});
					}

					$('#auto_leasing_marque_detail_id').removeAttr('disabled').attr( "selectedIndex", 0);
				},
			error: function(objRequest){


				$('#auto_leasing_marque_detail_id').removeAttr('disabled').removeOption(/./).addOption('', '-  Select Make  -');
			}
		});
	}
}


/**
* @ desc This will collect Available Models
*/
function collectNewModels(){

	var selectedId = 0;

	// Select which Marque Selector to choose dependant on car/van
	if( $('#new_car_is_van').val() == 1 ){

		var marqueId = $("#new_van_franchise_detail_id");
		var modelId   = $("#new_van_model_name");
		var variantId = $("#new_van_variant");
	}else{

		var marqueId = $("#new_car_franchise_detail_id");
		var modelId   = $("#new_car_model_name");
		var variantId = $("#new_car_variant");
	}

	modelId.attr('disabled', 'disabled');


	$.ajax({
		url: '/frontend-operations/new-model-list/',
		dataType: 'json',
		data: 'franchise_detail_id=' + marqueId.val() + '&is_van=' + $('#new_car_is_van').val(),
		success: function(data){

				// Remove all options
				modelId.removeOption(/./);
				variantId.removeOption(/./);

				// Add Options
				$.each(data, function(i,item){

					var option = modelId.addOption(item.id, item.references.heading);

					$( 'option:last', modelId ).data('url',item.url);
				});

				// If previously selected..
				if( selectedId > 0){
					modelId.selectOptions(selectedId);
				}else{
					// select 1st one if only one available
					var preSelect = ( data.length == 1 ) ? 1: 0;
					modelId.attr( "selectedIndex", preSelect);
				}
				modelId.removeAttr('disabled');
				if( modelId.attr( "selectedIndex") > 0 ){
					collectNewVariants();
				}
			},
		error: function(objRequest){

			modelId.removeAttr('disabled');
		}
	});
}


/**
* @ desc This will collect Available Variants
*/
function collectNewVariants(){

	var selectedId = 0;

	// Select which Marque Selector to choose dependant on car/van
	if( $('#new_car_is_van').val() == 1 ){

		var marqueId = $("#new_van_franchise_detail_id");
		var modelId   = $("#new_van_model_name");
		var variantId = $("#new_van_variant");
	}else{

		var marqueId = $("#new_car_franchise_detail_id");
		var modelId   = $("#new_car_model_name");
		var variantId = $("#new_car_variant");
	}

	variantId.attr('disabled', 'disabled');

	$.ajax({
		url: '/frontend-operations/new-variant-list/',
		dataType: 'json',
		data: 'franchise_detail_id=' + marqueId.val() + '&cms_page_area_link_id=' + modelId.val(),
		success: function(data){

				// Remove all options
				variantId.removeOption(/./);

				// Add Options
				$.each(data, function(i,item){

					variantId.addOption(item.id, item.variant);
				});

				// If previously selected..
				if( selectedId > 0){
					variantId.selectOptions(selectedId);
				}else{
					// select 1st one if only one available
					var preSelect = ( data.length == 1 ) ? 1: 0;
					variantId.attr( "selectedIndex", preSelect);
				}
				variantId.removeAttr('disabled');
			},
		error: function(objRequest){

			variantId.removeAttr('disabled');
		}
	});
}


function priceListing(){

	// Create list of price values for search box
	var i = 500;
	while ( i < 30001 ) {

		$("#lower_price").addOption(i, String.fromCharCode(163) + addCommas(i));
		$("#price").addOption(i, String.fromCharCode(163) + addCommas(i));

		if ( i < 10000 ) {
			i += 500;
		} else {
			i += 1000;
		}
	}
	$("#lower_price").addOption('999999', String.fromCharCode(163) + '30,000+').attr( "selectedIndex", 0);
	$("#price").addOption('999998', String.fromCharCode(163) + '30,000+').attr( "selectedIndex", 0);
}


/**
* @ desc This will collect Available Bodystyles, transmissions and fuel types
*/
function collectAdvancedSearchLists(){

	// Only load lists once
	if( advancedSearchLoaded != true ){

		// Remove all options and disable
		$('#advancedSearchLocation').attr('disabled', 'disabled');
		//$('#auto_body_style_detail_id').attr('disabled', 'disabled');
		//$('#auto_transmission_detail_id').attr('disabled', 'disabled');
		//$('#auto_fuel_type_detail_id').attr('disabled', 'disabled');
		$('#auto_tax_band').attr('disabled', 'disabled');

		$.ajax({
			url: '/frontend-operations/advanced-search-list/',
			dataType: 'json',
			data: '',
			success: function(data){

					advancedSearchLoaded = true;

					// Remove loading and show default select option
					$('#advancedSearchLocation').removeOption(/./).addOption('', '- Select Location -');
					//$('#auto_body_style_detail_id').removeOption(/./).addOption('', '- Select Bodystyle -');
					//$('#auto_transmission_detail_id').removeOption(/./).addOption('', '- Select Transmission -');
					//$('#auto_fuel_type_detail_id').removeOption(/./).addOption('', '- Select Fuel Type -');
					$('#auto_tax_band').removeOption(/./).addOption('', '- Select Tax Band -');

					// Add Options
					if( data.location != null ){
						$.each(data.location, function(i,item){
							$("#advancedSearchLocation").addOption(item.id, item.name);
						});
					}
					/*
					if( data.bodyStyle != null ){
						$.each(data.bodyStyle, function(i,item){
							$("#auto_body_style_detail_id").addOption(item.id, item.bodyStyleName);
						});
					}

					if( data.transmission != null ){
						$.each(data.transmission, function(i,item){
							$("#auto_transmission_detail_id").addOption(item.id, item.transmissionTypeName);
						});
					}

					if( data.fuel != null ){
						$.each(data.fuel, function(i,item){
							$("#auto_fuel_type_detail_id").addOption(item.id, item.fuelTypeName);
						});
					}
					*/
					if( data.taxBand != null ){
						$.each(data.taxBand, function(i,item){
							$("#auto_tax_band").addOption(item.band, 'Band ' + item.band + ' - ' + String.fromCharCode(163) + item.monthRate6 + '/' + String.fromCharCode(163) + item.monthRate12 + ' (6/12 months)' );
						});
					}

					$('#advancedSearchLocation').removeAttr('disabled').attr( "selectedIndex", 0);
					//$('#auto_body_style_detail_id').removeAttr('disabled').attr( "selectedIndex", 0);
					//$('#auto_transmission_detail_id').removeAttr('disabled').attr( "selectedIndex", 0);
					//$('#auto_fuel_type_detail_id').removeAttr('disabled').attr( "selectedIndex", 0);
					$('#auto_tax_band').removeAttr('disabled').attr( "selectedIndex", 0);
				},
			error: function(objRequest){

				$('#advancedSearchLocation').removeAttr('disabled').removeOption(/./).addOption('', '- Select Location -');
				//$('#auto_body_style_detail_id').removeAttr('disabled').removeOption(/./).addOption('', '- Select Bodystyle -');
				//$('#auto_transmission_detail_id').removeAttr('disabled').removeOption(/./).addOption('', '- Select Transmission -');
				//$('#auto_fuel_type_detail_id').removeAttr('disabled').removeOption(/./).addOption('', '- Select Fuel Type -');
				$('#auto_tax_band').removeAttr('disabled').removeOption(/./).addOption('', '- Select Tax Band -');
			}
		});
	}
}


/**
* @ desc This will collect Count of stock available
*/
function collectAdvancedSearchCount(){

	if( $('#tabVansSearch').hasClass('active') == true ){

		var extraParams = '&auto_marque_detail_id=' + $('#van_auto_marque_detail_id').val() + '&auto_model_detail_id=' + $('#van_auto_model_detail_id').val();
	}else{
		var extraParams = '&auto_marque_detail_id=' + $('#auto_marque_detail_id').val() + '&auto_model_detail_id=' + $('#auto_model_detail_id').val();
	}


	$.ajax({
		url: '/frontend-operations/advanced-search-count/',
		dataType: 'json',
		data: $('#frmSearchUsedCars').serialize() + extraParams,
		success: function(data){

				if( $('#tabUsedVans').hasClass('active') == true && data != null ){
				advancedSearchVanCount = data;
                    $('.vehicleResults').show();
					$('.vehicleResults').html('<img src="'+ netdirector.baseUrl +'/local/images/'+ netdirector.franchiseFolder +'iconVan.gif"><span>'+ data + ' Van(s) Found</span><div class="clear"></div>');
				}else if(data != null){
                advancedSearchCarCount = data;
                    $('.vehicleResults').show();
                    $('.vehicleResults').html('<img src="'+ netdirector.baseUrl +'/local/images/'+ netdirector.franchiseFolder +'iconCar.gif"><span>'+ data + ' Car(s) Found</span><div class="clear"></div>');
				}
			},
		error: function(objRequest){

		}

	});

}


function showCarSearch ( vehicleType ){
    
	if( vehicleType == 'bike' ){
		// Show bike tab
		$('#vehicleType').hide(); // category search

		$('#tabCarsSearch').removeClass('active');
		$('#tabVansSearch').removeClass('active');
		$('#tabBikesSearch').addClass('active');

		$('#advancedSearchDoors').attr( "selectedIndex", 0).hide();
		$('#auto_tax_band').attr( "selectedIndex", 0).hide();
		$('#search_url').val('bikes');
		$('#is_van').val(0);
		$('#is_bike').val(1);

	}else if( vehicleType == 'van' ){
		// Show van tab
		$('#vehicleType').hide();// category search


		$('#tabCarsSearch').removeClass('active');
		$('#tabBikesSearch').removeClass('active');
		$('#tabVansSearch').addClass('active');

		$('#advancedSearchDoors').attr( "selectedIndex", 0).hide();
		$('#auto_tax_band').attr( "selectedIndex", 0).hide();
		$('#search_url').val('vans');
		$('#is_van').val(1);
		$('#is_bike').val(0);

        $('#searchHeaderImage').attr('src',netdirector.baseUrl + '/local/images/'+ netdirector.franchiseFolder +'vehicleSearchVansTitle.gif');

	}else{
		// Show car tab
		$('#vehicleType').show(); // category search

		$('#tabVansSearch').removeClass('active');
		$('#tabBikesSearch').removeClass('active');
		$('#tabCarsSearch').addClass('active');

		$('#advancedSearchDoors').show();
		$('#auto_tax_band').show();
		$('#search_url').val('used-cars');
		$('#is_van').val(0);
		$('#is_bike').val(0);
        $('#searchHeaderImage').attr('src',netdirector.baseUrl + '/local/images/'+  netdirector.franchiseFolder +'vehicleSearchCarsTitle.gif');
	}
	setupStockTypeData( vehicleType ); // collect lists for select boxes
	$('.vehicleResults').html(''); // hide counter because nothing is selected
	$('#auto_model_detail_id').attr( "selectedIndex", 0); // Reset Models list
}



/*
* @ desc New cars selector between cars and vans
*/
function showNewCarSearch ( showCars ){

	if( showCars == true ){
		// Show car tab
		$('#new_van_franchise_detail_id').hide(); //hide the select object
		$('#tabContentNewVanSearch').hide(); // hide the tab
		$('#tabNewVansSearch').removeClass('active'); // deactivate the tab

		$('#new_car_franchise_detail_id').show();
		$('#tabContentNewCarSearch').show();
		$('#tabNewCarsSearch').addClass('active');

		$('#new_car_search_url').val('new-cars');
		$('#new_car_is_van').val(0);

	}else{
		// Show van tab
		$('#new_car_franchise_detail_id').hide(); //hide the select object
		$('#tabContentNewCarSearch').hide();  // hide the tab
		$('#tabNewCarsSearch').removeClass('active'); // deactivate the tab

		$('#new_van_franchise_detail_id').show();
		$('#tabContentNewVanSearch').show();
		$('#tabNewVansSearch').addClass('active');

		$('#new_car_search_url').val('new-cars');
		$('#new_car_is_van').val(1);
	}
}


/**
* @ desc sets and submits New Vehicles Search form
*/
function intelliQuickSearch(){

	if( currentISearch != $('#quick_search_value').val() ){

		rememberQuickVehicleSearchValue = $('#quick_search_value').val();

		if ( $('#quick_search_value').val() != '' && $('#quick_search_value').val() != 'Quick Vehicle Search' && $('#quick_search_value').val().length > 1 ) {

			var searchArray = $('#quick_search_value').val().toLowerCase().split(' ');

			$.ajax({
				url: '/frontend-operations/intelli-quick-search/',
				dataType: 'json',
				data: 'quick_search_value=' + $('#quick_search_value').val(),
				success: function(data){

						var text = ''; // per row
						var displayText = ''; // whole html for search results

						var names = ''; // per row collect
						var textNames = ''; // to stop similar results showing twice

						var searchItemArray = new Array();

						if (data != null) {

							displayText = '<table border="0" style="width: 100%;" cellpadding="0" cellspacing="0"><tr><th style="width: 100%; text-transform:uppercase;" colspan="2">Used Stock Search</th></tr>';

							$.each(data, function(i,item){

								text  = '';
								names = '';
								text += '<tr id="result_row_' + ++i + '" onmouseover="this.className = \'trOver\';" onmouseout="this.className=\'\';"><td style="width:60px;">';
								text += '<img src="' + netdirector.baseUrl + (( item.image_src != null && item.image_src != '' ) ? '/upload/images/stock/small/' + item.image_src : '/local/images/noImage72x54.gif' ) + '" alt="" class="float_left" style="width:60px;" /></td><td>';
								text += '<a href="javascript: submitQuickSearch(' + item.id + ');" title="' + item.marque_name + '" style="text-decoration:none; color:#666;" id="result_row_link_' + i + '">';

								searchItemArray[item.id] = item;

								//if( wordExists(searchArray,item.marque_name.toLowerCase()) == true  ){

									text += ' '  + item.marque_name;
									names += ' '  + item.marque_name;
								//}

								//if( wordExists(searchArray,item.model_name.toLowerCase()) == true  ){

									text += ' '  + item.model_name;
									names += ' '  + item.model_name;
								//}

								if( wordExists(searchArray,item.variant.toLowerCase()) == true  ){

									text += ' '  + item.variant;
									names += ' '  + item.variant;
								}

								//if( wordExists(searchArray,item.body_style_name.toLowerCase()) == true  ){

									text += ' '  + item.body_style_name;
									names += ' '  + item.body_style_name;
								//}

								if( wordExists(searchArray,item.fuel_type_name.toLowerCase()) == true  ){

									text += ' '  + item.fuel_type_name;
									names += ' '  + item.fuel_type_name;
								}

								if( wordExists(searchArray,item.transmission_type_name.toLowerCase()) == true  ){

									text += ' '  + item.transmission_type_name;
									names += ' '  + item.transmission_type_name;
								}

								if( wordExists(searchArray,item.registration_year.toLowerCase()) == true  ){

									text += ' '  + item.registration_year;
									names += ' '  + item.registration_year;
								}

								if( wordExists(searchArray,item.engine_size.toLowerCase()) == true  ){

									text += ' '  + item.engine_size + 'cc';
									names += ' '  + item.engine_size + 'cc';
								}

								if( wordExists(searchArray,item.full_registration.toLowerCase()) == true  ){

									text += ' '  + item.full_registration;
									names += ' '  + item.full_registration;
								}
								text += '</a></td>';

								//alert( displayTextNames.search(text) );
								if( textNames.search(names) < 0 ){
									textNames += names;
									displayText += text;
								}
							});
							displayText += '</table>';
							quickSearchResults = searchItemArray;
							totalResults = data.length;
							resultDisplayKeyboardHighlight = 0;
						}
						$('#searchResults').html(displayText);
						$('#searchResults').addClass('results');

						currentISearch = $('#quick_search_value').val(); // set the current value for remembrance
					},
				error: function(objRequest){

				}
			});
		} else {

			$('#searchResults').html('');
			$('#searchResults').removeClass('results');
			$('#searchResults').addClass('noResults');
		}
	}
}


/**
* @ desc sets and submits New Vehicles Search form
*/
function submitNewVehicleSearch(){

	var franchiseUrl, modelUrl, variantId, areaUrl

	if( $('#new_car_is_van').val() == 1 ){

		franchiseUrl  = $( '#new_van_franchise_detail_id option:selected').data('url');
		modelUrl   = $( '#new_van_model_name option:selected').data('url');
		variantId = $("#new_van_variant").val();
		areaUrl = 'new-vans';
	}else{

		franchiseUrl  = $( '#new_car_franchise_detail_id option:selected').data('url');
		modelUrl   = $( '#new_car_model_name option:selected').data('url');
		variantId = $("#new_car_variant").val();
		areaUrl = 'new-cars';
	}


	if( typeof modelUrl !== 'string' ){
		modelUrl = '';
	}else{
		modelUrl = '/' + modelUrl;
	}

	var url = netdirector.baseUrl + '/' + ( ( franchiseUrl != '' && franchiseUrl != 'group' ) ? franchiseUrl + '/' : '' )
			  + areaUrl + modelUrl;

	if(variantId) url += '/' + variantId;

	window.location = url
}


/**
* @ desc sets category and submits form
*/
function submitCategorySearch( category ){

	$('#category_search').val( category );
	$('#frmSearchUsedCars').submit();
}


/**
* @ desc submits quick search form
*/
function submitQuickSearch(id){


	var searchArray = $('#quick_search_value').val().toLowerCase().split(' ');
	var item = quickSearchResults[id];

	//if( wordExists(searchArray,item.marque_name.toLowerCase()) == true  ){

		$('#quick_search_marque_id').val( item.auto_marque_detail_id );
	//}

	//if( wordExists(searchArray,item.model_name.toLowerCase()) == true  ){

		$('#quick_search_model_id').val( item.auto_model_detail_id );
	//}

	if( wordExists(searchArray,item.variant.toLowerCase()) == true  ){

		$('#quick_variant').val( item.variant );
	}

	//if( wordExists(searchArray,item.body_style_name.toLowerCase()) == true  ){

		$('#quick_auto_body_style_detail_id').val( item.auto_body_style_detail_id );
	//}

	if( wordExists(searchArray,item.fuel_type_name.toLowerCase()) == true  ){

		$('#quick_auto_fuel_type_detail_id').val( item.auto_fuel_type_detail_id );
	}

	if( wordExists(searchArray,item.transmission_type_name.toLowerCase()) == true  ){

		$('#quick_auto_transmission_detail_id').val( item.auto_transmission_detail_id );
	}

	if( wordExists(searchArray,item.registration_year.toLowerCase()) == true  ){

		$('#quick_registration_year').val( item.registration_year );
	}

	if( wordExists(searchArray,item.engine_size.toLowerCase()) == true  ){

		$('#quick_engine_size').val( item.engine_size );
	}

	if( wordExists(searchArray,item.full_registration.toLowerCase()) == true  ){

		$('#quick_full_registration').val( item.full_registration );
	}
	$('#frmQuickSearchUsedCars').submit();
}


function quickSearchFocus(){

	if( $('#quick_search_value').val() == 'Quick Vehicle Search' ){

		if( rememberQuickVehicleSearchValue != '' ){
			$('#quick_search_value').val(rememberQuickVehicleSearchValue)
			$('#searchResults').html(rememberedDisplayText);
			$('#searchResults').addClass('results');
		}else{
			$('#quick_search_value').val('')
		}
	}
}


function quickSearchBlur(){

	$('#quick_search_value').val('Quick Vehicle Search');
	rememberedDisplayText = $('#searchResults').html();
	setTimeout( "hideQuickSearchResults()",300);
}


function hideQuickSearchResults(){

	if( rememberedDisplayText != '' ){
		$('#searchResults').animate({height: "toggle"}, 200, function(){

			$('#searchResults').html('');
			$('#searchResults').removeClass('results');
			$('#searchResults').addClass('noResults');
		});
	}
}


/**
* @ desc sets category and submits form
*/
function submitAdvancedSearch(){


	$('#search_marque_id').val( $('#auto_marque_detail_id').val() );
	$('#search_model_id').val( $('#auto_model_detail_id').val() );

	$('#frmSearchUsedCars').submit();
}

/**
* @ desc sets category and submits form
*/
function submitLeasingSearch(){


	$('#search_leasing_marque_id').val( $('#auto_leasing_marque_detail_id').val() );
	$('#search_leasing_model_id').val( $('#auto_leasing_model_detail_id').val() );

	$('#frmSearchLeasing').submit();
}

/**
* @ desc Adds commas in the right places to make long prices presentable
*/
function addCommas(nStr){

	nStr += '';
	var x = nStr.split('.');
	var x1 = x[0];
	var x2 = ( x.length > 1 ) ? '.' + ( ( x[1].length == 1 )? x[1] + '0' : x[1] ) : '';
	var rgx = /(\d+)(\d{3})/;

	while (rgx.test(x1)) {
		x1 = x1.replace(rgx, '$1' + ',' + '$2');
	}
	return x1 + x2;
}


function wordExists(arr, obj) {
	for(var i=0; i<arr.length; i++) {
		if( arr[i] != '' ){
			if (obj.search(arr[i]) >= 0) return true;
		}
	}
}


function detectkeyPress(e){

	var keycode;
	if (window.event) keycode = window.event.keyCode;
	else if (e) keycode = e.which;

	if( keycode == 40 ){
		keyboardDown();
	}else if( keycode == 38 ){
		keyboardUp();
	}else if( keycode == 13 ){
		keyboardReturn();
	}
}


function keyboardDown(){

	if( resultDisplayKeyboardHighlight < totalResults ){
		if( resultDisplayKeyboardHighlight > 0 ){
			$( '#result_row_' + resultDisplayKeyboardHighlight ).removeClass('trOver');
		}
		resultDisplayKeyboardHighlight += 1;
		$( '#result_row_' + resultDisplayKeyboardHighlight ).addClass('trOver');
	}
}


function keyboardUp(){

	if( resultDisplayKeyboardHighlight > 1 ){
		$( '#result_row_' + resultDisplayKeyboardHighlight ).removeClass('trOver');
		resultDisplayKeyboardHighlight -= 1;
		$( '#result_row_' + resultDisplayKeyboardHighlight ).addClass('trOver');
	}
}


function keyboardReturn(){

	if( resultDisplayKeyboardHighlight > 0 ){
		$( '#result_row_link_' + resultDisplayKeyboardHighlight ).focus();
		window.location = $( '#result_row_link_' + resultDisplayKeyboardHighlight ).attr( 'href' );
		return false;
	}
}




/**
* @ desc This save a vehicle to favourites via Ajax
*/
function addToMyFavourites( vehicleId ){

	$('body').css('cursor', 'progress');
    

	$.ajax({
	  url: '/frontend-operations/save-vehicle-to-favourites/',
	  dataType: 'json',
	  data: 'auto_car_detail_id=' + vehicleId,
	  success: function(data){

			if( data == true ){

				// Favourite has been added successfully
				alert( 'Vehicle has been saved' );
				showMyFavourites();
			}else{
                alert( 'Vehicle has already been saved' );
				// Favourite failed to save
			}
			$('body').css('cursor', 'default');
		},
	error: function( objRequest ){
			// Could not save favourite
			$('body').css('cursor', 'default');
		}
	});

}



/**
* @ desc This adds a vehicle to compare via Ajax
*/
function addToCompare( vehicleId ){

	$('body').css('cursor', 'progress');

	$.ajax({
	  url: '/frontend-operations/add-vehicle-to-compare/',
	  dataType: 'json',
	  data: 'auto_car_detail_id=' + vehicleId,
	  success: function(data){

			if( data['error'] != null && data['error'] != '' ){

				$('input[value='+vehicleId+']').attr('checked', false);
				alert( data['error'] );

			}
			$('body').css('cursor', 'default');
		},
	error: function( objRequest ){

			$('body').css('cursor', 'default');
		}
	});
}


/**
* @ desc This removes vehicle from compare via Ajax
*/
function removeFromCompare( vehicleId ){

	$('body').css('cursor', 'progress');

	$.ajax({
	  url: '/frontend-operations/remove-vehicle-from-compare/',
	  dataType: 'json',
	  data: 'auto_car_detail_id=' + vehicleId,
	  success: function(data){

			$('body').css('cursor', 'default');

			if ( $('#CompareTbl tbody tr:first td:visible').length <= 2 ) {
				$('#CompareTbl').html("");
				$('#compareNoVehiclesSelected').show();
			} else {
                //alert( 'Vehicle has been removed from compare list.' );
				$('.compare_'+vehicleId).fadeOut();
			}

		},
	error: function( objRequest ){

			$('body').css('cursor', 'default');
		}
	});
}


/**
* @desc Removes all vehicles stored for compare via Ajax
*/
function removeAllFromCompare() {

	$('body').css('cursor', 'progress');

	$.ajax({
	  url: '/frontend-operations/remove-all-from-compare/',
	  dataType: 'json',
	  data: '',
	  success: function(data){

			$('body').css('cursor', 'default');
			$('#CompareTbl').html("");
			$('#compareNoVehiclesSelected').show();
		},
	error: function( objRequest ){

			$('body').css('cursor', 'default');
		}
	});
}


/**
* @ desc remove this vehicle to favourites via Ajax
*/
function removeFavourite( vehicleId ){

	$('body').css('cursor', 'progress');

	$.ajax({
	  url: '/frontend-operations/remove-vehicle-from-favourites/',
	  dataType: 'json',
	  data: 'auto_car_detail_id=' + vehicleId,
	  success: function(data){

			if( data == true ){
                
				// Favourite has been removed successfully
				window.location = netdirector.baseUrl + '/' + netdirector.franchiseUrl + 'used-cars/favourites';
                //alert('Vehicle has been removed from your wishlist. You will now not be able to retrieve this vehicle.');
                
			}else{

				// Favourite failed to remove
			}
          removeFromCompare(vehicleId);
			$('body').css('cursor', 'default');
		},
	error: function( objRequest ){
			// Could not save favourite
			$('body').css('cursor', 'default');
		}
	});
}


function showMyFavourites(){
    
	$('body').css('cursor', 'progress');

	$.ajax({
	  url: '/frontend-operations/view-my-favourites/',
	  dataType: 'json',
	  data: 'limit=' + 6,
	  success: function(data){

			if( data != 0 ){

				var vehicleTitle, vehicleLink, itemClass;
                var text = '';
                var count = 1;

				// Add Options
				$.each(data, function(i,item){
                    
                    var image = '/local/images/noImage171x128.gif';
                    if (item.imageSrc !== null) {
                        image = '/upload/images/stock/small/' + item.imageSrc;
                    }

					vehicleTitle = item.references.marque_name + ' ' + item.references.model_name + ' ' + item.variant;
                    vehicleLink = netdirector.baseUrl + '/' + netdirector.franchiseUrl + 'used-cars/' + item.id + '/' + vehicleTitle.toLowerCase().replace( ' ', '-' );

                    count == 3 ? itemClass = 'class="last"' : itemClass = '';

					text += '<div id="thumb'+(i+1)+'" ' + itemClass + '><a href="' + vehicleLink + '" title="' + vehicleTitle + '">' +
                            '<span class="frame"><img src="' + netdirector.baseUrl + '/local/images/frame63x47.png" alt="' + vehicleTitle + '" style="width:63px; height:47px" /></span>' +
                            '<img src="' + netdirector.baseUrl + image + '" alt="' + vehicleTitle + '" style="width:63px; height:47px" />' +
                            '</a></div>';

                    count == 3 ? count = 1 : count++;
				});

                $('#sideThumbs').html(text);

				$('#btnSave').show();
				$('#btnCompare').show();
				$('#btnRetrieve').hide();
			}else{

				// Could not retrieve favourites
				$('#btnSave').hide();
				$('#btnCompare').hide();
				$('#btnRetrieve').show();
			}
			$('body').css('cursor', 'default');
		},
	error: function( objRequest ){
			// Could not retrieve favourites
			$('#btnSave').hide();
			$('#btnCompare').hide();
			$('#btnRetrieve').show();
			$('body').css('cursor', 'default');
		}
	});
}



/**
* @ desc This will save the temporary stored favourites to the database
*/
function saveFavourites(){

	// Check if form is valid before proceeding
	if( $( "#formSaveFavourites" ).valid() ){

		$('body').css('cursor', 'progress');

		$.ajax({
		  url: '/frontend-operations/save-favourites/',
		  dataType: 'json',
		  data: $( '#formSaveFavourites' ).serialize(),
		  success: function(data){

				if( data != 0 ){

					// Submitted ok.

					updateTips('Saved','You can now come back and view your saved vehicles anytime.','highlight','','alertBoxSaveFavourites');

					clearFormElements("#formSaveFavourites");
					setTimeout( "autoCloseDialog('dialogSaveFavourites');",4000);

				}else{

					// Show generic message
					updateTips('Request Failed','The form submit request failed, please try again.','error','','alertBoxSaveFavourites');
				}
				$('body').css('cursor', 'default');
			},
		error: function( objRequest ){
				updateTips('Request Failed','The request to submit failed, please try again.','error','','alertBoxSaveFavourites');
				$('body').css('cursor', 'default');
			}
		});
	}
}



/**
* @ desc This will retrieve previously stored favourites
*/
function retrieveFavourites(){

	// Check if form is valid before proceeding
	if( $( "#formRetrieveFavourites" ).valid() ){

		$('body').css('cursor', 'progress');

		$.ajax({
		  url: '/frontend-operations/retrieve-favourites/',
		  dataType: 'json',
		  data: $( '#formRetrieveFavourites' ).serialize(),
		  success: function(data){

				if( data == true ){

					// Submitted ok.
					updateTips('Retrieved','Redirecting..','highlight','','alertBoxRetrieveFavourites' );

					setTimeout( "window.location = netdirector.baseUrl + '/' + netdirector.franchiseUrl + 'used-cars/favourites';", 500);

				}else{

					// Show generic message
					updateTips('Request Failed','The email you have provided was not found in our system','error','','alertBoxRetrieveFavourites' );
				}
				$('body').css('cursor', 'default');
			},
		error: function( objRequest ){
				updateTips('Request Failed','The request to submit failed, please try again.','error','','alertBoxRetrieveFavourites' );
				$('body').css('cursor', 'default');
			}
		});
	}
}



/**
* @ desc This will populate the select boxes with data according to vehicle type
*/
function setupStockTypeData( vehicleType ){

	setupMarqueData( 'auto_marque_detail_id', vehicleType );
	$('#auto_model_detail_id').removeOption(/./); // Remove models because we have re-generated marques
	setupBodystyleData( 'auto_body_style_detail_id', vehicleType );
	setupFuelData( 'auto_fuel_type_detail_id', vehicleType );
	setupTransmissionData( 'auto_transmission_detail_id', vehicleType );
}


/**
* @ desc This will populate the Marque List select box
*/
function setupMarqueData( elementId, vehicleType ){

	var thisSelection = '#' + elementId;

	// Remove all options
	$( thisSelection ).attr('disabled', 'disabled').removeOption(/./).addOption('', '- Select Marque -');

	// Add Options
	if( $.inArray(vehicleType, possibleVehicleTypes) > -1 ){
		$.each(selectMarqueList[vehicleType], function(i,item){

			if( parseInt( item.count ) > 0 ){
				$( thisSelection ).addOption(item.id, item.marqueName.toUpperCase());
			}
		});
	}
	$( thisSelection ).removeAttr('disabled').attr( "selectedIndex", 0);

	// Remember Search Params
	if( searchParams.makeId > 0 ){

		$( thisSelection ).selectOptions( searchParams.makeId );

		collectAvailableModels( searchParams.modelId, true);

	}else if (!netdirector.isGroup) {

        // If no previous search data, use defaults
        $( thisSelection ).selectOptions( netdirector.defaultAutoMarqueDetailId );
        collectAvailableModels( searchParams.modelId, true);
    }
        collectAdvancedSearchCount();
}


/**
* @ desc This will populate the Bodystyle List select box
*/
function setupBodystyleData( elementId, vehicleType ){

	var thisSelection = '#' + elementId;

	// Remove all options
	$( thisSelection ).attr('disabled', 'disabled').removeOption(/./).addOption('', '- Select Body Style -');

	// Add Options
	if( $.inArray(vehicleType, possibleVehicleTypes) > -1 ){
		$.each(selectBodystyleList[vehicleType], function(i,item){
			$( thisSelection ).addOption(item.id, item.bodyStyleName.toUpperCase());
		});
	}
	$( thisSelection ).removeAttr('disabled').attr( "selectedIndex", 0);
}


/**
* @ desc This will populate the Fuel List select box
*/
function setupFuelData( elementId, vehicleType ){

	var thisSelection = '#' + elementId;

	// Remove all options
	$( thisSelection ).attr('disabled', 'disabled').removeOption(/./).addOption('', '- Select Fuel Type -');

	// Add Options
	if( $.inArray(vehicleType, possibleVehicleTypes) > -1 ){
		$.each(selectFuelList[vehicleType], function(i,item){
			$( thisSelection ).addOption(item.id, item.fuelTypeName.toUpperCase());
		});
	}
	$( thisSelection ).removeAttr('disabled').attr( "selectedIndex", 0);
}

/**
* @ desc This will populate the Transmission List select box
*/
function setupTransmissionData( elementId, vehicleType ){

	var thisSelection = '#' + elementId;

	// Remove all options
	$( thisSelection ).attr('disabled', 'disabled').removeOption(/./).addOption('', '- Select Transmission Type -');

	// Add Options
	if( $.inArray(vehicleType, possibleVehicleTypes) > -1 ){
		$.each(selectTransmissionList[vehicleType], function(i,item){
			$( thisSelection ).addOption(item.id, item.transmissionTypeName.toUpperCase());
		});
	}
	$( thisSelection ).removeAttr('disabled').attr( "selectedIndex", 0);
}




/**
 *
 * Monthly repayment calculator, everything else int
 *
 * loanAmmount - the total ammount to be financed
 *
 * apr - the APR rate ( As a decimal e.g. 0.1 == 10% )
 *
 * term - number of months that the loan will last.
 */
function monthlyRepayments( principle, apr, term ){

	var monthlyRate = apr/12;

	return Math.floor( ( principle * monthlyRate ) / ( 1 - Math.pow( ( 1 + monthlyRate ),( -1 * term ) ) ) * 100 ) / 100;


}

/**
* @ desc This will open the dialog and show the correct form
*/
function showCustomForm( formType ){

	var dialogName = '';
	var formName   = '';

	// Using switch will stop JS errors from passing incorrect dialog names
	switch( formType ){

		case 'customvaluemyvehicle':
			dialogName   = 'dialogCustomValueMyVehicle';
			formName     = 'formCustomValueMyVehicle';
			alertBoxName = 'alertBoxCustomValueMyVehicle';

			collectAllMakes('#custom_valuemyvehicle_my_make_id', 0);
		break;

		default:
			dialogName = 'dialog'+ formType;
			formName = 'form'+ formType;
			alertBoxName = 'alertBox'+ formType;
		break;
	}

	if( dialogName != '' ){
		console.log(dialogName, formName, alertBoxName);

		// Clear the form values
		clearFormElements('#' + formName);

		// Removes validation messages
		var validator = $('#' + formName).validate();
		validator.resetForm();

		// Clear Alert Box Text
		resetTips( alertBoxName, true );

		// Open the dialog box
		$('#' + dialogName ).dialog( "option", "position", 'center' );
		$('#' + dialogName ).dialog('open');

		// highlight first input
		$('#' + dialogName + ' :input:text:first').focus();

		displayFormCaptchaImage( '#' + formName );
	}
}


/**
* @ desc This will setup form
*/
function setupCustomForm(formType){
	if ($('#form'+ formType +' .customVehicleMake').length > 0) {
		collectAllMakes('#form'+ formType +' .customVehicleMake', 0);
		$('#form'+ formType +' .customVehicleMake').change(function() {
			collectAllModels('#form'+ formType +' .customVehicleModel', this.value, 0);
		});
	}

	// Clear the form values
	clearFormElements('#form' + formType);

	// Removes validation messages
	var validator = $('#form' + formType).validate();
	validator.resetForm();

	// Clear Alert Box Text
	$('#alertBox' + formType).html('');
}

/**
* @ desc This will save the selected areas for this franchise via Ajax
*/
function submitCustomForm( formType, isUsingDialogBox ){

	if( formType != '' ){

		// Check if form is valid before proceeding
		if( $( "#form" + formType ).valid()){
            
            if( formType == 'CustomRecruitmentApplication' ){
            
                $('#formCustomRecruitmentApplication').attr('action','/frontend-operations/submit-form/');
                $('#formCustomRecruitmentApplication').submit();
                updateTips('Application sent','Thank you for your application. We will respond as soon as possible','highlight','','alertBox' + formType);
                clearFormElements("#form" + formType); 
                return;
                
            }
            
			var formData = $( '#form' + formType ).serialize();
			if ($('#form'+ formType +' .customVehicleMake').length > 0) {
				formData += '&customers_vehicle_make=' + $('#form' + formType + ' .customVehicleMake > option:selected').text()
					+ '&customers_vehicle_model=' + $('#form' + formType + ' .customVehicleModel > option:selected').text() + '&';
			}

			formStatus(formType, true);
			updateTips('<img src="/local/images/loading.gif" width="15" style="position:relative; display:inline; top:4px; margin:0 5px" />Submiting Form', '', 'highlight', '', 'alertBox' + formType);

			if( formType == 'customvaluemyvehicle' ){
				var formData = 'my_make=' + $('#custom_valuemyvehicle_my_make_id > option:selected').text() + '&my_model=' + $('#custom_valuemyvehicle_my_model_id > option:selected').text() + '&';
			}

			$.ajax({
				url: '/frontend-operations/submit-form/',
				dataType: 'json',
				data: formData,
				success: function(data) {

					// Enable submit button and default cursor.
					$( '#form' + formType + ' input, #form' + formType + ' textarea, #form' + formType + ' select').removeAttr('disabled');
					$( '#form' + formType ).data('disable', false);
					$('body').css('cursor', 'default');

					if( data.status == true ){
                        if ( typeof itForm == 'function' ) {
						    itForm(data.intellitracker);
                        }

						if( isUsingDialogBox == true ){
							// Submitted ok.
							if( formType == 'ShareWithFriend' ){
								updateTips('Email sent','Your friend should recieve the email shortly.','highlight','','alertBox' + formType);
							}else{
								updateTips('Enquiry sent','Thank you for your enquiry. We will respond as soon as possible','highlight','','alertBox' + formType);
							}

							clearFormElements("#form" + formType);

						}else{
							updateTips('Thank You','Your details have been submitted successfully','highlight','','alertBox' + formType);
							clearFormElements("#form" + formType);
						}

						//Google analytics tracking
						window._gaq = window._gaq || [];
						window._gaq.push(['_trackPageview',  netdirector.baseUrl + "/" + netdirector.franchiseUrl + 'submit-form/' + encodeURIComponent( formType ) ]);
						
						setTimeout(function(){
							autoCloseDialog('dialog' + formType);
							formStatus(formType, false);
						}, 4000);

					}else{

						displayFormCaptchaImage( '#form' + formType );

						if( data.error != null ){
							updateTips('Request Failed',data.error,'error','','alertBox' + formType);
						}else{
							updateTips('Request Failed','The request to submit failed, please try again.','error','','alertBox' + formType);
						}

						formStatus(formType, false);
					}
				},
				error: function( objRequest ){
					formStatus(formType, false);
					updateTips('Request Failed','The request to submit failed, please try again.','error','','alertBox' + formType);
				}
			});
		}
	}
}


function formStatus(formType, disable) {

	var id = '#form' + formType, height = 400;

	if (typeof formType === 'undefined') {
		return false;
	}

	if (disable) {
		// Store the form's original height.

		// Loading cursor and disabled submit button.
		$('body').css('cursor', 'progress');
		$(id + ' input, ' + id + ' textarea, ' + id + ' select').attr('disabled', true);

		$(id)
			.data('disable', true)
			.data('originalHeight', $(id).innerHeight())
			.animate({
				height : 0,
				opacity : 0
			}, 400, function () {
				$(this).css('display', 'none')
			})
			.parent()
			.next()
			.slideUp(300);

	} else {

		if (typeof $(id).data('originalHeight') !== 'undefined') {
			height = $(id).data('originalHeight');
		}

		$(id)

		// Enable submit button and default cursor.
		$(id + ' input, ' + id + ' textarea, ' + id + ' select').removeAttr('disabled');
		$('body').css('cursor', 'default');

		$(id)
			.css('display', 'block')
			.data('disable', false)
			.animate({
				height : height + 'px',
				opacity : 100
			}, 400)
			.parent()
			.next()
			.slideDown(300);
	}
}

/**
 * @ desc This will share this page URL on facebook
 */
function shareOnFacebook(url){
	if (typeof url == 'undefined') {
		url = document.location;
	}

	var url = "http://www.facebook.com/sharer.php?u=" + encodeURIComponent(url);
	window.open(url,'sharer','toolbar=0,status=0,width=626,height=436');
	itEvent('shareOnFacebook');
}


function showShareWithFriend (options) {
	console.log (options, typeof options, typeof options.id, typeof options.nonexist, $form, $('.full_uri', $form));
	showCustomForm('CustomShareWithFriend');
	if (typeof options != 'undefined') {
		var $form = $('#formCustomShareWithFriend');
		if (typeof options.fullUrl != 'undefined') {
			$('.full_uri', $form).val(options.fullUrl);
		}
		if (typeof options.id != 'undefined') {
			$('.page_id', $form).val(options.id);
		}
		if (typeof options.url != 'undefined') {
			$('.page_uri', $form).val(options.url);
		}
	}
}

