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  = 3;
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() {
    
    //collectCAPLeasingVehicleMarqueLists();
    collectCAPLeasingOffersMarqueLists();
    
	// Create tabs and start them working
    $("#tabVehicleSearch").tabs();
	$("#tabNewVehicleSpec").tabs();
	$("#tabUsedVehicleInfo").tabs();
    // Display search form (is set to display:none to prevent fouc)
    $('#tabVehicleSearch').css('display', 'block');
	// Display search form (is set to display:none to prevent fouc)
    $('#newCarOptions').css('display', 'block');
	// Create tabs and start them working
    $("#newCarOptions").tabs();
	$("#cwFinanceOptions").tabs();
	
	$('input[name=addToCompare]').change( function( event ) {
		if ( event.target.checked ) {
			addToCompare( event.target.value );
		} else {
			removeFromCompare( event.target.value );
		}
	});

	// Generate Price
	priceListing();
    
    // Populate New Car Marque List
    // collectNewVehicleMarqueListsCustom();
	
    // rememberSearchSettings();
	// 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': function() {
				retrieveFavourites();
			},
			Cancel: 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': function() {
				saveFavourites();
			},
			Cancel: 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();

    // Generate GUID for intellitracker.
	if( typeof itGuid === 'undefined' ){
		itGenerateGuid();
	}

    // Work around for webkit scrollbar problem when using jquery ui dialog :|
    if ($.browser.webkit) {
        $('div[id*=dialog]').bind('dialogopen', function(){
            setTimeout(function(){
                $(document).unbind('mousedown.dialog-overlay').unbind('mouseup.dialog-overlay');
            }, 1);
        });
        $('div[id*=newCarOverlay]').bind('dialogopen', function(){
            setTimeout(function(){
                $(document).unbind('mousedown.dialog-overlay').unbind('mouseup.dialog-overlay');
            }, 1);
        });
    }

	// table mouse over styling
	$('.trOut').mouseover(function(){
		$(this).addClass('trOver').removeClass('trOut');
	}).mouseout(function(){
		$(this).addClass('trOut').removeClass('trOver');
	})

});


/**
* @ 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');

	}else{

		showCarSearch('car');
	}
}


/**
* @ 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').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();
				}
			},
		error: function(objRequest){

			modelId.removeAttr('disabled');
		}
	});
}

/**
* @ desc This will collect New Vehicle Marque Lists
*/

function collectCAPLeasingVehicleMarqueLists(){

    // Only load lists once
    if( leasingVehicleSearchLoaded != true ){

        // Remove all options and disable
        $('#auto_leasing_marque_detail_id').attr('disabled', 'disabled');

        $.ajax({
            url: '/frontend-operations/cap-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.makes != null ){
                        $.each(data.makes, function(i,item){
                            $("#auto_leasing_marque_detail_id, #financeenquiry_marque").addOption(item.capMakeId, item.makeName);
                        });
                    }

                    $('#auto_leasing_marque_detail_id, #financeenquiry_marque').removeAttr('disabled').attr( "selectedIndex", 0);

                    if ( typeof defaultMarque != 'undefined' ) {
                        $('#auto_leasing_marque_detail_id').val(defaultMarque);
                        if ( typeof defaultModel != 'undefined' ) {
                            collectCAPLeasingModels(defaultModel);
                        } else {
                            collectCAPLeasingModels();
                        }
                    }

					if (typeof financeenquiry_marque !== 'undefined')
					{
						$('#financeenquiry_marque option').each
						(
							function ()
							{
								if ($(this).html().toString().toLowerCase() === financeenquiry_marque.toLowerCase())
								{
									$(this).attr('selected', true);
								}
							}
						);
					}

                },
            error: function(objRequest){

                $('#auto_leasing_marque_detail_id, #financeenquiry_marque').removeAttr('disabled').removeOption(/./).addOption('', '-  Select Make  -');
            }
        });
    }
}

function collectCAPLeasingModels(selectedId, quote){

	quote = typeof quote === 'undefined' ? false : true;

	if (quote) {
		var marqueId = $('#financeenquiry_marque').val();
		var modelId = $('#financeenquiry_model');
	} else {
		var marqueId = $("#auto_leasing_marque_detail_id").val();
    	var modelId  = $("#auto_leasing_model_detail_id");
	}


    modelId.attr('disabled', 'disabled');

    $.ajax({
        url: '/frontend-operations/cap-leasing-vehicle-model-list/',
        dataType: 'json',
        data: 'marque_id=' + marqueId,
        success: function(data){

                // Remove all options
                modelId.removeOption(/./);

                // Add Options
            if(data != null) {
                $.each(data.models, function(i,item){

                    modelId.addOption(item.capModelId, item.modelName);
                });
            }
                // If previously selected..
                if( selectedId != null && selectedId > 0){

                    modelId.val(selectedId);

                }else{
                    // select 1st one if only one available
                    var preSelect = ( (data != null) && (data.length == 1) ) ? 1: 0;
                    modelId.attr( "selectedIndex", preSelect);
                }
                modelId.removeAttr('disabled');

            },
        error: function(objRequest){

            modelId.removeAttr('disabled');
        }
    });
}

/**
* @ desc This will collect New Vehicle Marque Lists
*/
function collectCAPLeasingOffersMarqueLists(){

    // Only load lists once
    if( leasingVehicleSearchLoaded != true ){

        // Remove all options and disable
        $('#auto_leasing_marque_detail_id').attr('disabled', 'disabled');

        $.ajax({
            url: '/frontend-operations/cap-leasing-offers-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.makes != null ){
                        $.each(data.makes, function(i,item){
                            $("#auto_leasing_marque_detail_id, #financeenquiry_marque").addOption(item.capMakeId, item.makeName);
                        });
                    }

                    $('#auto_leasing_marque_detail_id, #financeenquiry_marque').removeAttr('disabled').attr( "selectedIndex", 0);

                    if ( typeof searchParams != 'undefined' ) {
                        $('#auto_leasing_marque_detail_id').val(searchParams.makeId);
                        if ( typeof searchParams.modelId != 'undefined' ) {
                            collectCAPLeasingModels(searchParams.modelId);
                        } else {
                            collectCAPLeasingModels();
                        }
                    }

					if (typeof financeenquiry_marque !== 'undefined')
					{
						$('#financeenquiry_marque option').each
						(
							function ()
							{
								if ($(this).html().toString().toLowerCase() === financeenquiry_marque.toLowerCase())
								{
									$(this).attr('selected', true);
								}
							}
						);
					}

                },
            error: function(objRequest){

                $('#auto_leasing_marque_detail_id, #financeenquiry_marque').removeAttr('disabled').removeOption(/./).addOption('', '-  Select Make  -');
            }
        });
    }
}

/**
* @ 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 All Makes under a particular Vehicle Type
*/
function collectAllCAPMarques(){
var isVan = 0;
	var marqueId = $('#manufacturer');
	marqueId.attr('disabled', 'disabled');

	$.ajax({
		url: '/frontend-operations/all-marques/',
		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..
				
					// 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 All Models under a particular Make
*/
function collectCAPModels(){

	var modelId = $('#car_mdoel');
	modelId.attr('disabled', 'disabled');

	$.ajax({
		url: '/frontend-operations/all-models/',
		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 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  -');
			}
		});
	}
}

/*
 This is a custom function that collects the available marques
 */
function collectNewVehicleMarqueListsCustom(){

	// Only load lists once
	if( newVehicleSearchLoaded != true ){

		// Remove all options and disable
		$('#new_car_cms_page_id').attr('disabled', 'disabled');
var vehicleFound = '';
		$.ajax({
			url: '/frontend-operations/new-car-makes/',
			dataType: 'json',
			data: '',
			success: function(data){

					newVehicleSearchLoaded = true;

					// Remove loading and show default select option
					$('#new_car_cms_page_id').removeOption(/./).addOption('', '-  Marque  -');

					// Add Options
					if( data.newMarque != null ){
						$.each(data.newMarque, function(i,item){
							$("#new_car_cms_page_id").addOption(item.id, item.makeName);
							$( '#new_car_cms_page_id option:last' ).data('url',item.fullUrl);
                            if(jQuery.inArray(searchParams.newCarMakeId,item.id)) {
                                vehicleFound = 'true';
                            }
						});
                        
					}
                    
                    if(vehicleFound == 'true'){
                        $('#new_car_cms_page_id').removeAttr('disabled');
                        //$( "#new_car_cms_page_id" ).val( searchParams.newCarMakeId );
                        //$( "#new_car_subpage" ).val( searchParams.newCarModelId );
                        collectNewModelsCustom();
                    }
                

					//$('#new_car_cms_page_id').removeAttr('disabled').attr( "selectedIndex", 0);

				},
			error: function(objRequest){

				$('#new_car_cms_page_id').removeAttr('disabled').removeOption(/./).addOption('', '-  Marque  -');
			}
		});
	}
}

/*
 This is a custom function that collects the available models
 */
function collectNewModelsCustom(){

	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_cms_page_id");
		var modelId   = $("#new_car_cms_subpage_id");
		var variantId = $("#new_car_variant");
	}

	modelId.attr('disabled', 'disabled');


	$.ajax({
		url: '/frontend-operations/new-car-models/',
		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(/./);
				$.each(data, function(i,item){
                    //console.log(data.id)
                });
				// Add Options
				$.each(data.newModel, function(i,item){

					var option = modelId.addOption(item.id, item.modelName);

					$( 'option:last', modelId ).data('url',item.url);
				});
                
                
            modelId.removeAttr('disabled');
                if( searchParams.newCarModelId > 0){
                    
                    modelId.val( searchParams.newCarModelId );
                }
                else{
                    // 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){

			
		}
	});
}


/**
* @ 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_cms_page_id");
		var modelId   = $("#new_car_cms_subpage_id");
		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( $('#tabVansSearch').hasClass('active') == true ){

					advancedSearchVanCount = data;
					$('#vehicleCountDisplay').html(data + ' Van(s) Available');
				}else{
					advancedSearchCarCount = data;
					$('#vehicleCountDisplay').html(data + ' Car(s) Available');
				}
			},
		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);

	}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);
	}
	setupStockTypeData( vehicleType ); // collect lists for select boxes
	$('#vehicleCountDisplay').html(''); // hide counter because nothing is selected
	$('#new_car_cms_subpage_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_cms_page_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_cms_page_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

    franchiseUrl  = $( '#new_car_cms_page_id option:selected').data('url');
    modelUrl   = $( '#new_car_cms_subpage_id option:selected').data('url');
    areaUrl = 'new-cars';
	
	var url = netdirector.baseUrl + '/' + areaUrl + '/' + franchiseUrl;
    if(modelUrl) url += '/' + modelUrl;

	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(){

    if($('#auto_leasing_marque_detail_id').val() == ''){
        alert('Please select a vehicle marque');
    }else{

        $('#search_leasing_marque_id').val( $('#auto_leasing_marque_detail_id').val() );
        $('#search_leasing_model_id').val( $('#auto_leasing_model_detail_id').val() );
    
        $('#frmVehicleSearch').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 will post the (custom cms) form via Ajax
*/
function submitCustomForm( formType ){

	if( formType == '' ){
		return;
	}

	// Check if form is valid before proceeding
	if( $( "#form" + formType ).valid() ){

		$('body').css('cursor', 'progress');

		$.ajax({
		  url: '/frontend-operations/submit-form/',
		  dataType: 'json',
		  data: $( '#form' + formType ).serialize(),
		  success: function(data){

				if( data != 0 ){

                    itForm(data.intellitracker);

                    $( '#alertBox' + formType ).css( "display", "block" );
					// Submitted ok.
					setupCustomForm( formType );
					updateTips('Thank You','Your details have been submitted successfully','highlight','','alertBox' + formType);

					//Google analytics tracking
					window._gaq = window._gaq || [];
                    window._gaq.push(['_trackPageview', netdirector.baseUrl + "/" + 'submit-form/' + encodeURIComponent( formType ) ]);

				}else{
                    $( '#alertBox' + formType ).css( "display", "block" );
					// Show generic message
					updateTips('Request Failed','The request to submit failed, please try again.','error','','alertBox' + formType);
				}
				$('body').css('cursor', 'default');
			},
		error: function( objRequest ){
                $( '#alertBox' + formType ).css( "display", "block" );
				updateTips('Request Failed','The request failed to submit, please try again.','error','','alertBox' + formType);
				$('body').css('cursor', 'default');
			}
		});
	}
}

/**
* @ desc This will setup form
*/
function setupCustomForm(formType){

	// Clear the form values
	clearFormElements('#form' + formType);

	// Removes validation messages
	var validator = $('#form' + formType).validate();
	validator.resetForm();

	// Clear Alert Box Text
	$('#alertBox' + formType).html('');

	// highlight first input
    //removed as causing page to jump down
	//$('#form' + formType + ' :input:text:first').focus();
}


/**
* @ 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{

				// 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 {
				$('.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';
			}else{

				// Favourite failed to remove
			}
			$('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=' + favouritesLimit,
	  success: function(data){

			if( data != 0 ){

				var vehicleTitle, text;

				// Add Options
				$.each(data, function(i,item){

					vehicleTitle = item.references.marque_name + ' ' + item.references.model_name + ' ' + item.variant;
					text = '<a href="' + netdirector.baseUrl + '/' + netdirector.franchiseUrl + 'used-cars/' + item.id + '/' + vehicleTitle.toLowerCase().replace( ' ', '-' ) + '" title="' + vehicleTitle + '"><img src="' + netdirector.baseUrl + '/upload/images/stock/small/' + item.imageSrc + '" alt="' + vehicleTitle + '" style="width:40px;" /></a>';

					$('#favouriteItem_' + ( i + 1 ) ).html( text );
				});

				$('#favouritesSave').show();
				$('#favouritesCompare').show();
				$('#favouritesRetrieve').hide();
			}else{

				// Could not retrieve favourites
				$('#favouritesSave').hide();
				$('#favouritesCompare').hide();
				$('#favouritesRetrieve').show();
			}
			$('body').css('cursor', 'default');
		},
	error: function( objRequest ){
			// Could not retrieve favourites
			$('#favouritesSave').hide();
			$('#favouritesCompare').hide();
			$('#favouritesRetrieve').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 );
    //setupMarqueData( 'new_car_franchise_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);

//    alert(searchParams.newCarMake);
    
	// Remember Search Params
    
	if( searchParams.newCarMake){
    
        //alert(searchParams.newCarMake);
		$( thisSelection ).selectOptions( searchParams.newCarMake );
	
		//collectNewModelsCustom( searchParams.newCarModel, true);

	}else{
    
        // If no previous search data, use defaults
        $( thisSelection ).selectOptions( netdirector.defaultAutoMarqueDetailId );
        collectNewModelsCustom( searchParams.newCarModel, true);
    }
}


/**
* @ 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);
}

