var advancedSearchLoaded   = 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() {

    $("#custom_preferred_date").datepicker();
	$('#custom_preferred_date').datepicker('option', {showAnim: 'fadeIn',dateFormat: 'dd/mm/yy'});

	// Create tabs and start them working
    $("#tabVehicleSearch").tabs();
	$("#tabNewVehicleSpec").tabs();
	$("#tabUsedVehicleInfo").tabs();
    $("#tabOfferList").tabs();



	// Generate Price
	priceListing();
	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);
    });



});


/**
* @ 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();
		validator.resetForm();

		if( alertBoxName != '' ){

			// Clear Alert Box Text
			resetTips( alertBoxName );
		}

		// Open the dialog box
		$('#' + dialogName ).dialog('open');

		// highlight first input
		$('#' + dialogName + ' :input:text:first');
	}
}


/**
* @ desc This will attempt to reset any options selected in the search
*/
function rememberSearchSettings(){

	// Remember Search Params
	if( parseInt( searchParams.makeId ) > 0 ){

		$("#auto_marque_detail_id").selectOptions( searchParams.makeId );
		collectAvailableModels( searchParams.modelId, 0);
	}

	if( parseInt( searchParams.vanMakeId ) > 0 ){
		$("#van_auto_marque_detail_id").selectOptions( searchParams.makeId );
		collectAvailableModels( searchParams.vanModelId, 1);
	}
}


/**
* @ 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><span class=\"ui-icon ui-icon-alert\" style=\"float: left; margin: 0px 5px;\"></span>"+txt+"</p>";
			alertBox.addClass('ui-state-error').html(msg);
		break;

		case 'highlight':
			msg = "<p><span class=\"ui-icon ui-icon-info\" style=\"float: left; margin: 0px 5px;\"></span>"+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');
	}
}


/**
* @ desc This Resets the dialog alert box
*/
function resetTips(alertBoxId){

	alertBox = ( alertBoxId != null && alertBoxId != '' ) ? $('#'+alertBoxId) : $('#dialogAlertBox');
	alertBox.removeClass('ui-state-error ui-state-highlight').html('');
}


/**
* @ 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, isVan){

	if( isVan == 1 ){
		var marqueId = $("#van_auto_marque_detail_id");
		var modelId = $("#van_auto_model_detail_id");
	}else{
		var marqueId = $("#auto_marque_detail_id");
		var modelId = $("#auto_model_detail_id");
	}

	modelId.attr('disabled', true);

	ndCollector(
		'/frontend-operations/available-model-list/',
		'marque_id=' + marqueId.val() + '&is_van=' + isVan,
		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 > 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');
			// calculate vehicle count
			collectAdvancedSearchCount();
		},
		function(objRequest){

			modelId.removeAttr('disabled');
		}
	);
}



/**
* @ desc This will collect Available Models
*/
function collectNewModels(){

	var selectedId = 0;

	var marqueId = $("#new_car_franchise_detail_id");
	var modelId  = $("#new_car_model_name");
	var variantId = $("#new_car_variant");

	modelId.attr('disabled', true);

	ndCollector(
		'/frontend-operations/new-model-list/',
		'franchise_detail_id=' + marqueId.val(),
		function(data){

			// Remove all options
			modelId.removeOption(/./);
			variantId.removeOption(/./);

			// Add Options
			$.each(data, function(i,item){

				modelId.addOption(item.model_name, item.model_name);
			});

			// 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();
			}
		},
		function(objRequest){

			modelId.removeAttr('disabled');
		}
	);
}


/**
* @ desc This will collect Available Variants
*/
function collectNewVariants(){

	var selectedId = 0;

	var marqueId  = $("#new_car_franchise_detail_id");
	var modelId   = $("#new_car_model_name");
	var variantId = $("#new_car_variant");

	variantId.attr('disabled', true);

	ndCollector(
		'/frontend-operations/new-variant-list/',
		'franchise_detail_id=' + marqueId.val() + '&model_name=' + modelId.val(),
		function(data){

			// Remove all options
			variantId.removeOption(/./);

			// Add Options
			$.each(data, function(i,item){

				variantId.addOption(item.url, 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');
		},
		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, '£' + addCommas(i));
		$("#price").addOption(i, '£' + addCommas(i));

		if ( i < 10000 ) {
			i += 500;
		} else {
			i += 1000;
		}
	}
	$("#lower_price").addOption('999999', '£30,000+').attr( "selectedIndex", 0);
	$("#price").addOption('999998', '£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');

		ndCollector(
			'/frontend-operations/advanced-search-list/',
			'',
			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 -');

				// 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);
					});
				}

				$('#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);
			},
			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 -');
			}
		);
	}
}


/**
* @ 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();
	}

	ndCollector(
		'/frontend-operations/advanced-search-count/',
		$('#frmSearchUsedCars').serialize() + extraParams,
		function(data){

			if( $('#tabVansSearch').hasClass('active') == true ){

				advancedSearchVanCount = data;
				$('#vehicleCountDisplay').html(data + ' Van(s) Available');
			}else{
				advancedSearchCarCount = data;
				$('#vehicleCountDisplay').html(data + ' Car(s) Available');
			}
		},
		function(objRequest){

		}
	);
}


function showCarSearch ( showCars ){

	if( showCars == true ){
		// Show car tab
		$('#vehicleType').show();
		$('#tabContentVanSearch').hide();
		$('#tabVansSearch').removeClass('active');
		$('#tabContentCarSearch').show();
		$('#tabCarsSearch').addClass('active');
		$('#advancedSearchDoors').show();
		$('#advancedSearchTaxBand').show();
		$('#search_url').val('used-cars');
		$('#is_van').val(0);
		$('#vehicleCountDisplay').html(advancedSearchCarCount + ' Car(s) Available');

	}else{
		// Show van tab
		$('#vehicleType').hide();
		$('#tabContentCarSearch').hide();
		$('#tabCarsSearch').removeClass('active');
		$('#tabContentVanSearch').show();
		$('#tabVansSearch').addClass('active');
		$('#advancedSearchDoors').hide();
		$('#advancedSearchTaxBand').hide();
		$('#search_url').val('vans');
		$('#is_van').val(1);
		$('#vehicleCountDisplay').html(advancedSearchVanCount + ' Van(s) Available');
	}
}


/**
* @ 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(' ');

			ndCollector(
				'/frontend-operations/intelli-quick-search/',
				'quick_search_value=' + $('#quick_search_value').val(),
				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
				},
				function(objRequest){

				}
			);
		} else {

			$('#searchResults').html('');
			$('#searchResults').removeClass('results');
			$('#searchResults').addClass('noResults');
		}
	}
}


/**
* @ desc sets and submits New Vehicles Search form
*/
function submitNewVehicleSearch(){

	window.location = $('#frmSearchNewCars').attr('action') + $('#new_car_variant').val();
}


/**
* @ 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(){

	if( $('#tabVansSearch').hasClass('active') == true ){

		$('#search_marque_id').val( $('#van_auto_marque_detail_id').val() );
		$('#search_model_id').val( $('#van_auto_model_detail_id').val() );
	}else{

		$('#search_marque_id').val( $('#auto_marque_detail_id').val() );
		$('#search_model_id').val( $('#auto_model_detail_id').val() );
	}
	$('#frmSearchUsedCars').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 );
		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() ){

             //console.dir( $( "#form" + formType + ' label.error'));
            $( "#form" + formType + ' label.error').each(function(){
                $(this).removeClass('error');
                 //console.log(this);

            })

		$('body').css('cursor', 'progress');

		$.ajax({
		  url: '/frontend-operations/submit-form/',
		  dataType: 'json',
		  data: $( '#form' + formType ).serialize(),
		  success: function(data){

                itForm(data.intellitracker);
              
				if( data != 0 ){

					// Submitted ok.
					setupCustomForm( formType );
					updateTips('Thank You','Your details have been submitted successfully','highlight','','alertBox' + formType);
                    

				}else{

					// Show generic message
					updateTips('Request Failed','The request to submit failed, please try again.','error','','alertBox' + formType);
				}
				$('body').css('cursor', 'default');
			},
		error: function( objRequest ){
				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
	$('#form' + formType + ' :input:text:first');
}



/**
* @ desc This save a vehicle to favourites via Ajax
*/
function addToMyFavourites( vehicleId ){

    $.ajax({
      url: '/frontend-operations/view-my-favourites/',
      dataType: 'json',
      data: 'limit=9999',
      success: function(data){

            if (data.length>=6){

                alert('Comparison list full. Please remove vehicles before adding more');
                $('body').css('cursor', 'default');

            }else{

                $.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{

                $.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
                            alert( 'Vehicle has not been saved or it already exists in your favourites' );
                        }
                        $('body').css('cursor', 'default');
                    },
                    error: function( objRequest ){
                            // Could not save favourite
                            $('body').css('cursor', 'default');
                    }
                });

            }
                        $('body').css('cursor', 'default');
                    },
                    error: function( objRequest ){
                            // Could not save favourite
                            $('body').css('cursor', 'default');
                    }
                });

            }
        },
        error: function( objRequest ){
                // Could not retrieve favourites
                $('body').css('cursor', 'default');
            }
    });

                $('body').css('cursor', 'progress');

}



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;
                        var image = '/local/images/noImage224x168.gif';
                        if (item.imageSrc !== null) {
                            image = '/upload/images/stock/small/' + item.imageSrc;
                        }


                        text = '<a href="' + netdirector.baseUrl + '/' + netdirector.franchiseUrl + 'used-cars/' + item.id + '/' + vehicleTitle.toLowerCase().replace( ' ', '-' ) + '" title="' + vehicleTitle + '"><img src="' + netdirector.baseUrl + image + '" alt="' + vehicleTitle + '" style="height:65px; width:85px;"/></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.

                    itEvent('saveToFavourites');
                    
					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');
			}
		});
	}
}

//when the drop down with id new_car_franchise_detail_id is active call the updateModelList function.
//and do the same for new_car_model_name, calling the newCarSearch function
$(function(){
    $("#new_car_franchise_detail_id").change( function(){ updateModelList() })
    $("#new_car_model_name").change( newCarSearch )
    updateModelList();
})

function updateModelList (){

    if(!$('#new_car_franchise_detail_id').val()) return;

    //frontendOperations is the file name.
    $.ajax({
		url: netdirector.baseUrl + "/frontend-operations/get-new-car-model-list/",
		dataType: 'json',
		data: {franchiseId: $('#new_car_franchise_detail_id').val()},
		success: function(data){

            $("#new_car_model_name").empty();

            $("<option />").attr("value", "").text(" - Please Select - ").appendTo($("#new_car_model_name"));

            $.each(data, function(i, page){
                $("<option />").attr("value", page.fullUrl ).text(page.references.cmsPageContent.heading).appendTo($("#new_car_model_name"));
            })

        }
	});
}


//this is the url once the franchise and car have been selected will be fired off to.
function newCarSearch(){
    if(!$("#new_car_model_name").val()) return;

    //get the value of the looped over hidden variable and the select id and put them together into franNom. 
    var franNom = $("#franchiseName_"+$("#new_car_franchise_detail_id").val()).val();

    window.location = netdirector.baseUrl+'/' + franNom + "/new-cars/" + $("#new_car_model_name").val();

}









/**
* @ desc This will populate the Marque List select box
*/
function setupAllMarqueData( 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){


		    $( thisSelection ).addOption(item.id, item.marqueName.toUpperCase());

		});
	}
	$( thisSelection ).removeAttr('disabled').attr( "selectedIndex", 0);
}





/**
* @ 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-vehicles/favourites';
			}else{

				// Favourite failed to remove
			}
			$('body').css('cursor', 'default');
		},
	error: function( objRequest ){
			// Could not save favourite
			$('body').css('cursor', 'default');
		}
	});
}

