var snto = null;
jQuery(document).ready(function() { 
				
		if(document.getElementById('snsel'))
		{
			clearnav()
		}

		try
		{
		jQuery('#topnav a').hoverIntent(sn, sn);
		jQuery('#navgroup').hoverIntent(dn, clearnav);
		}
		catch(e) {
			debugger;
			}

		jQuery('.blockbutton').click(function() { bui('1'); }); 
		jQuery('.blockbutton1').click(function() { bui('1'); }); 
		jQuery('.blockbutton2').click(function() { bui('2'); }); 
		jQuery('.blockbutton3').click(function() { bui('3'); }); 
		jQuery('.blockbutton4').click(function() { bui('4'); }); 
	
		jQuery.swapImage(".swapImage", true, true, "mouseenter", "mouseleave");

		try
		{
		jQuery('.aviaslider').aviaSlider({
			blockSize: {
			height: 40,
			width: 'full'
		},
		display: 'topleft',
		transition: 'fade',
		betweenBlockDelay: 150,
		animationSpeed: 600,
		switchMovement: false,
			appendControlls: '.aviacontrols'
		});
		}
		catch(e) {}

		jQuery('.faq .que a').click(function(){
			jQuery('.faq .ans').hide();
			$(this).parent().next().show('slow');
			return false;
		});

		jQuery('#viewmore').click(function(){
			$("#openingtext").hide();
			$("#moreinfo").show();
			return false;
			// $(this).parent().prev().trigger('click');

		});
		jQuery('#viewless').click(function(){
			$("#moreinfo").hide();
			$("#openingtext").show();
			return false;
			// $(this).parent().prev().trigger('click');

		});

		jQuery('#fader').innerfade(
							   { 
							   speed: 'slow', timeout: 5000, type: 'sequence'
							   }); 
	
		jQuery.validator.messages.required = "Required field";
		jQuery('#formvalidator').validate({
									 
			rules: {
			},
			invalidHandler: function(e, validator) {
				var errors = validator.numberOfInvalids();
				if (errors) {
					jQuery.unblockUI();
					var message = errors == 1
						? 'You missed 1 field. It has been highlighted for you.'
						: 'You missed ' + errors + ' fields.  They have been highlighted for you.';
						alert(message);
					jQuery("#warning span").html(message);
					jQuery("#warning").show();
				} else {
					jQuery("#warning").hide();
				}
			},
		errorPlacement: function(error, element) { 
            if ( element.is(":radio") ) 
                element.addClass('missingfield');
            else if ( element.is(":checkbox") ) 
                element.addClass('missingfield');
            else 
				element.addClass('missingfield');
	        }, 
			
			highlight: function(element, errorClass) {
    			 // jQuery(element).fadeOut(function() { jQuery(element).fadeIn() })
			  }

		})
	try {
	$('.productscroll').serialScroll({
		target:'.slider',
		items:'li', // Selector to the items ( relative to the matched elements, '#sections' in this case )
		prev:'img.prev',// Selector to the 'prev' button (absolute!, meaning it's relative to the document)
		next:'img.next',// Selector to the 'next' button (absolute too)
		//axis:'Y',// The default is 'y' scroll on both ways
		//navigation:'#navigation li a',
		duration:250,// Length of the animation (if you scroll 2 axes and use queue, then each axis take half this time)
		force:true, // Force a scroll to the element specified by 'start' (some browsers don't reset on refreshes)
		step:1,
		start:0,	
		//interval:3000,
		cycle:true,
		
		//queue:false,// We scroll on both axes, scroll both at the same time.
		//event:'click',// On which event to react (click is the default, you probably won't need to specify it)
		//stop:false,// Each click will stop any previous animations of the target. (false by default)
		//lock:true, // Ignore events if already animating (true by default)		
		//start: 0, // On which element (index) to begin ( 0 is the default, redundant in this case )		
		//cycle:true,// Cycle endlessly ( constant velocity, true is the default )
		//step:2, // How many items to scroll each time ( 1 is the default, no need to specify )
		//jump:false, // If true, items become clickable (or w/e 'event' is, and when activated, the pane scrolls to them)
		//lazy:false,// (default) if true, the plugin looks for the items on each event(allows AJAX or JS content, or reordering)
		//interval:1000, // It's the number of milliseconds to automatically go to the next
		//constant:true, // constant speed
		
		onBefore:function( e, elem, $pane, $items, pos ){
			/**
			 * 'this' is the triggered element 
			 * e is the event object
			 * elem is the element we'll be scrolling to
			 * $pane is the element being scrolled
			 * $items is the items collection at this moment
			 * pos is the position of elem in the collection
			 * if it returns false, the event will be ignored
			 */
			 //those arguments with a $ are jqueryfied, elem isn't.
			e.preventDefault();
			if( this.blur )
				this.blur();
		},
		onAfter:function( elem ){
			//'this' is the element being scrolled ($pane) not jqueryfied
		}
	});
	}
	catch(e) {
		alert(e.message);
		}
		

	// initialize scrollable
	try {
		
	$(".scrollable").scrollable(
								{ circular: true,
								next:'.scrollablenext',
								prev:'.scrollableprev',
								items:'scrolleritems'
								} 
								
								);
	}
	catch(e) {}




	}
)

function bui(append)
{
	if (!append) { append = '1'; }
	var theDiv = 'processing'+append;
	var theMessage = document.getElementById(theDiv).innerHTML;
	jQuery.blockUI({ 
            message:theMessage, 
            css: {  border: 'none', 
            padding: '10px', 
            backgroundColor: '#fff', 
            '-webkit-border-radius': '10px', 
            '-moz-border-radius': '10px', 
            opacity: .95, 
            color: '#fff' } 
        }); 
	
}

