/*   
=============================================================================== 
Base jQuery file
...............................................................................
                                                                        2010/04
------------------------------------------------------------------------------- 
COPY / USE AT YOUR OWN SITE'S RISK
=============================================================================== 
*/



//tabs
			$(function(){
				// Tabs
				$('#tabs').tabs({ fx: { opacity: 'toggle' } });
				
				//hover states on the static widgets
				$('#dialog_link, ul#icons li').hover(
					function() { $(this).addClass('ui-state-hover'); }, 
					function() { $(this).removeClass('ui-state-hover'); }
					);
				
				//generic fade in
				$(".fade").delay(1000).animate({opacity:1},1000); 
				
			});



jQuery.fn.paneTogglerInit = function(e) {
	var togglerParent = jQuery(e);
	var firstChild = jQuery(this).children('li:first');
	var currentPane = firstChild.find('a').attr('rel');
	//alert(currentPane);
	
	firstChild.addClass('current');
	togglerParent.find('li[rel="'+currentPane+'"]').addClass('current').siblings().addClass('disabled');
}
jQuery.fn.paneTogglerClick = function(e) {
	var togglerParent = jQuery(e);
	var currentPane = jQuery(this).attr('rel');
	var isCurrent = jQuery(this).parent().hasClass('current');
	var isInfo = jQuery(this).parent().hasClass('info');

	if ( !isCurrent && !isInfo ) {
		jQuery(this)
			.closest('li').addClass('current')
			.siblings('.current').removeClass('current');
		togglerParent.find('li.current')
			.animate({
				left: '-600px'
				},400, function() {
				
				}
			)
			.removeClass('current');
		togglerParent.find('li[rel="'+currentPane+'"]')
			.css({
				left:0,
				opacity:0
			})
			.animate({
				opacity:1
				},800
			)
			.addClass('current');
	}
}
 
// pre-submit callback 
function showRequest(formData, jqForm, options) { 
    // formData is an array; here we use $.param to convert it to a string to display it 
    // but the form plugin does this for you automatically when it submits the data 
    var queryString = $.param(formData); 
 
    // jqForm is a jQuery object encapsulating the form element.  To access the 
    // DOM element for the form do this: 
    // var formElement = jqForm[0]; 
 
    alert('About to submit: \n\n' + queryString); 
 
    // here we could return false to prevent the form from being submitted; 
    // returning anything other than false will allow the form submit to continue 
    return true; 
} 
 
// post-submit callback 
function showResponse(responseText, statusText, xhr, $form)  { 
    // for normal html responses, the first argument to the success callback 
    // is the XMLHttpRequest object's responseText property 
 
    // if the ajaxSubmit method was passed an Options Object with the dataType 
    // property set to 'xml' then the first argument to the success callback 
    // is the XMLHttpRequest object's responseXML property 
 
    // if the ajaxSubmit method was passed an Options Object with the dataType 
    // property set to 'json' then the first argument to the success callback 
    // is the json data object returned by the server 
 
    alert('status: ' + statusText + '\n\nresponseText: \n' + responseText + 
        '\n\nThe output div should have already been updated with the responseText.'); 
}



jQuery(document).ready( function() {	
	jQuery('.paneToggleControl').paneTogglerInit('.paneToggler');
	jQuery('.paneToggleControl > li > a').not('[rel=tour]').click( function() {
		jQuery(this).paneTogglerClick('.paneToggler');
	});
	jQuery('.toggleSTF').click( function(){
		jQuery('.actions + .sendToFriend').toggle(600);
	});
	
	
	//http://jquery.malsup.com/form/
    var options = { 
        target:        '#sendToFriendOutput',   // target element(s) to be updated with server response 
        beforeSubmit:  showRequest,  // pre-submit callback 
        success:       showResponse  // post-submit callback 
 
        // other available options: 
        //url:       url         // override for form's 'action' attribute 
        //type:      type        // 'get' or 'post', override for form's 'method' attribute 
        //dataType:  null        // 'xml', 'script', or 'json' (expected server response type) 
        //clearForm: true        // clear all form fields after successful submit 
        //resetForm: true        // reset the form after successful submit 
 
        // $.ajax options can be used here too, for example: 
        //timeout:   3000 
    }; 
 
    // bind to the form's submit event 
    jQuery('#sendToFriend').submit(function() { 
        // inside event callbacks 'this' is the DOM element so we first 
        // wrap it in a jQuery object and then invoke ajaxSubmit 
        jQuery(this).ajaxSubmit(options); 
 
        // !!! Important !!! 
        // always return false to prevent standard browser submit and page navigation 
        return false; 
    }); 
    
	
	//siteplan popup for cottages
		jQuery(".sitePlanEnlarge").fancybox();
	
})
