/* Copyright 2006 LuckyTeam.co.uk. To use this code on your own site, visit http://luckyteam.co.uk */

function _el(id){ return document.getElementById(id); }

function _els(name){ return document.getElementsByName(name); }

function getXMLHttpRequest(){
    var xmlhttp_form = false;
    if(window.XMLHttpRequest) {
        try {
            xmlhttp_form = new XMLHttpRequest();
        } catch(e) {
            xmlhttp_form = false;
        }
    } else if(window.ActiveXObject) {
        try {
            xmlhttp_form = new ActiveXObject("Msxml2.XMLHTTP");
        } catch(e) {
            try {
                xmlhttp_form = new ActiveXObject("Microsoft.XMLHTTP");
            } catch(e) {
                xmlhttp_form = false;
            }
        }
    }
    return xmlhttp_form;
}

function _addEventListener(obj, event, listener){
    if(ua == 'gecko' || ua == 'opera'){
        obj.addEventListener(event, listener, false);
    } else if (ua == 'msie') {
        obj.attachEvent("on"+event,listener);
    }
};

function _removeEventListener(obj, event, listener){
    if(ua == 'gecko' || ua == 'opera'){
        obj.removeEventListener(event, listener, false);
    } else if (ua == 'msie') {
        obj.detachEvent("on"+event,listener);
    }
};


/* Copyright 2006 LuckyTeam.co.uk. To use this code on your own site, visit http://luckyteam.co.uk */

var ua = 'msie';
var W=navigator.userAgent.toLowerCase();
if(W.indexOf("opera")!=-1){ua='opera';}else if(W.indexOf("msie")!=-1){ua='msie';} else if(W.indexOf("mozilla")!=-1){ua='gecko';}

/* Copyright 2006 LuckyTeam.co.uk. To use this code on your own site, visit http://luckyteam.co.uk */

var xmlhttp_form = false;
var curform = null;

function checkForm(form, name){

    xmlhttp_form = getXMLHttpRequest();

    if (!xmlhttp_form) {
        return true;
    }

    var url = baseuri + '/forms/'+name+'/check';

    if (typeof tinyMCE != 'undefined'){
        tinyMCE.triggerSave();
    }

    var params = getFormValues(form);

    curform = form;

    xmlhttp_form.onreadystatechange = checkFormCallback;
    xmlhttp_form.open('POST', url, true);
    xmlhttp_form.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
    xmlhttp_form.setRequestHeader("Content-length", params.length);
    xmlhttp_form.setRequestHeader("Connection", "close");
    xmlhttp_form.send(params);

    return false;
}

function checkFormCallback()
{
    if (xmlhttp_form.readyState==4){
        if (xmlhttp_form.status == 200) {
            var r, re;
            var s = xmlhttp_form.responseText;
            re_re = new RegExp("<script(.*?)>","ig");
            s = s.replace(re_re,"");
            re_re = new RegExp("</script>","ig");
            s = s.replace(re_re,"");
            if(s == "" || s == "OK"){
                curform.submit();
            } else {
                eval(s);
            }
        } else {
            alert("There was a problem retrieving the XML data:\n" + xmlhttp_form.statusText);
        }
    }
}

function getFormValues(form)
{
   var str = "";
   for(var i = 0;i < form.elements.length;i++)
   {
        switch(form.elements[i].type)
        {
            case "text":
            case "hidden":
            case "textarea":
            case "password":
            case "file":
                str += form.elements[i].name + "=" + escape(form.elements[i].value).replace(/\+/g,'%2B') + "&";
                break;
            case "checkbox":
            case "radio":
                if(form.elements[i].checked){
                    str += form.elements[i].name + "=" + escape(form.elements[i].value).replace(/\+/g,'%2B') + "&";
                }
                break;
            case "select-one":
                str += form.elements[i].name + "=" + form.elements[i].options[form.elements[i].selectedIndex].value + "&";
                break;
            case "select-multiple":
                for(var k = 0;k < form.elements[i].options.length; k++){
                    if(form.elements[i].options[k].selected){
                        str += form.elements[i].name + "=" + form.elements[i].options[k].value + "&";
                    }
                }
                break;
        }
    }

    str = str.substr(0,(str.length - 1));
    return str;
}

/* Copyright 2006 LuckyTeam.co.uk. To use this code on your own site, visit http://luckyteam.co.uk */

String.prototype.trim = function() {
    return this.replace(/(^\s*)|(\s*$)/g, "");
}

String.prototype.htmltrim = function() {
    return this.trim().replace(/(^<br>)|(<br>$)/g, "");
}

String.prototype.toLink = function(addTags) {
    var replacers = {
        url: function(str) {

            var pattern = /((href=(?:'|")?)?(https?:\/\/|www\.)(\S+)(\/(?:\S+))?)/;
            return str.replace(pattern, function($0,$1,$2,$3,$4,$5) {
                    if ( $2 ) {return $1;}
                    if ("undefined" == typeof($5) ) { $5 = ""; }
                    return "<a href='"
                            +(('www.'==$3) ? 'http://': '')
                            +$3+$4+$5 +"'"
                            + " " + addTags + " "
                            + ">"
                            +$3+$4+$5+"</a>";
            });
        }, 
        email: function(str) { 
            var pattern = /([\w\.!#\$%\-+.]+@[A-Za-z0-9\-]+(\.[A-Za-z0-9\-]+)+)/;
            
            return str.replace(pattern, "<a href='mailto:$1'>$1</a>");
            
            return str.replace(pattern, function($0,$1,$2,$3,$4,$5) {
                    return "<a href='mailto:"
                            +$1
                            +"'>"
                            +$1+"</a>";
            });
        }
    }
    
    var s = this;
    for (var r in replacers) {
        s =  replacers[r](s);
    }
    return s;
}

var xmlhttp = false;
var xmlhttp_v = false;

function initRequest(){

    var xmlhttptemp = false;

    if(window.XMLHttpRequest) {
        try {
            xmlhttptemp = new XMLHttpRequest();
        } catch(e) {
            xmlhttptemp = false;
        }
    } else if(window.ActiveXObject) {
        try {
            xmlhttptemp = new ActiveXObject("Msxml2.XMLHTTP");
        } catch(e) {
            try {
                xmlhttptemp = new ActiveXObject("Microsoft.XMLHTTP");
            } catch(e) {
                xmlhttptemp = false;
            }
        }
    }
    return xmlhttptemp;
}

function get_phone_code(country) {
    xmlhttp = initRequest();
    xmlhttp.onreadystatechange=set_phone_code;
    xmlhttp.open("GET", baseuri + '/phone_code?country='+escape(country).replace(/\+/g,'%2B'), true);
    xmlhttp.send(null);
}

function set_phone_code()
{
    if (xmlhttp.readyState==4){
        if (xmlhttp.status == 200) {
            if(xmlhttp.responseText.length == 0){
                _el('phone_code').value='';
//                _el('f_phone_code').value='';
            } else {
                _el('phone_code').value = xmlhttp.responseText;
                _el('phone_code').size = _el('phone_code').value.length;
            }
        } else {
            alert("There was a problem retrieving the XML data:\n" + xmlhttp.statusText);
        }
    }
}


function properties_do_search(from) {
    xmlhttp = initRequest();

    var area = _el('area').value;
    var style = _el('s_style').value;
    var capacity = _el('s_capacity').value;
    var sort = _el('s_sort').value;
    var keyword = _el('s_keyword').value;


    xmlhttp.onreadystatechange=show_propertiessearch_results;
    xmlhttp.open("GET", baseuri + '/properties/qsearch/?'
        +'from='+escape(from).replace(/\+/g,'%2B')
        +'&area='+escape(area).replace(/\+/g,'%2B')
        +'&style='+escape(style).replace(/\+/g,'%2B')
        +'&capacity='+escape(capacity).replace(/\+/g,'%2B')
        +'&sort='+escape(sort).replace(/\+/g,'%2B')
        +'&keyword='+escape(keyword).replace(/\+/g,'%2B')
        +((arguments.length==2)?'&new_page_count='+escape(arguments[1]).replace(/\+/g,'%2B'):'')
        , true);

    xmlhttp.send(null);
}
function show_propertiessearch_results()
{
    if (xmlhttp.readyState==4){
        if (xmlhttp.status == 200) {
            _el('p1').innerHTML = xmlhttp.responseText;
        } else {
            alert("There was a problem retrieving the XML data:\n" + xmlhttp.statusText);
        }
    }
}


function change_page_results(url_prefix, new_count) {
    document.location = baseuri + url_prefix 
        + ((url_prefix.indexOf("?")>=0)?"&":"?") 
        + "new_page_count=" + escape(new_count).replace(/\+/g,'%2B');
}
function change_search_page_result(url, new_count) {
    document.location = baseuri + url + 'per_page-' + new_count + '/'; 
}

var oldThumbID = -1;
function changeThumbnail(id, width, height, title, size) {
    _el('hlpStr').style.visibility = 'hidden';

    /*
    if (oldThumbID!=-1) {
        _el('td'+oldThumbID).className = '';
    }
    */
    oldThumbID = id;
    _el('luckySmallTitle').innerHTML = title;
    /*
    _el('td'+id).className = 'thumbSelected';
    */
    if (width>=500 /*&& height>=500*/) {
        _el('luckySmall').innerHTML = '<div id="sc2" class="luckyZoomSmallImageCont"><img width="250" height="'+(250*height/width)+'" id="sim2" src="'+baseuri+'/img/image_'+id+'_250.jpg" alt=""/>'+
                '<div id="bc2" class="luckyZoomBigImageCont" style="width:300px; height:300px; left: 255px; top: 0px"><img onload="initZoom('+width+');" id="bim2" alt="" width="'+width+'" height="'+height+'" src="'+baseuri+'/img/image_'+id+'.jpg" /></div></div>';
    zoom = new luckyZoom('sc2', 'sim2', 'bc2', 'bim2');
    zoom.initZoom();
    } else {
        _el('luckySmall').innerHTML = '<img width="'+width+'" height="'+height+'" id="sim2" src="'+baseuri+'/img/image_'+id+'.jpg" alt=""/>';
    }
    //_el('downloadLink').href = baseuri+'/attachment/'+id;
    return false;
}


function sync_billing_info() {
    xmlhttp = initRequest();
    xmlhttp.onreadystatechange= function() {
        if (xmlhttp.readyState==4){
            if (xmlhttp.status == 200) {
                var r, re;
                var s = xmlhttp.responseText;
                re_re = new RegExp("<script(.*?)>","ig");
                s = s.replace(re_re,"");
                re_re = new RegExp("</script>","ig");
                s = s.replace(re_re,"");
                if(s != ""){
                    eval(s);
                }
            } else {
                alert("There was a problem retrieving the XML data:\n" + xmlhttp_form.statusText);
            }
        }
    };
    xmlhttp.open("GET", baseuri + "/account/billinginfo_sync?", true);
    xmlhttp.send(null);
}


function movePhoto( id, dir ) {
    var cur = _el('photo_'+id);
    var next = null;
    
    if ( 'up'==dir ) {
        next = cur.previousSibling;
        while ("TR" != next.tagName) { next=next.previousSibling; }
    } else if ( 'down'==dir ) {
        next = cur.nextSibling;
        while ("TR" != next.tagName) { next=next.nextSibling; }
    }
    
    if ( undefined == next || !/^photo_/.test(next.id) ) {
        return;
    }
    
    swapNodes(cur,next);
    cur_n = _el(cur.id+"_title").innerHTML;
    next_n = _el(next.id+"_title").innerHTML;


    if ( "" != _el(cur.id+"_title").innerHTML.htmltrim() ) {
        _el(cur.id+"_title").innerHTML = next_n;
        _el(next.id+"_title").innerHTML = cur_n;
    } else if ( "" != _el(next.id+"_title").innerHTML.htmltrim() ) {
        _el(next.id+"_title").innerHTML = cur_n;
        _el(cur.id+"_title").innerHTML = next_n;
    }
}

function requests_booking_status(id, status) {
    xmlhttp = initRequest();

    xmlhttp.open("GET", baseuri + "/account/requests/booking_status/?id=" + id + "&status=" + status, true);
    xmlhttp.send(null);
}

function enquiries_do_qsearch(from){
    xmlhttp = initRequest();
    var status = _el('s_status').value;
    var property = _el('s_property').value;

    xmlhttp.onreadystatechange=show_enquiriessearch_results;
    xmlhttp.open("GET", baseuri + '/account/rrequests/qsearch/?'
        +'s_status='+escape(status).replace(/\+/g,'%2B')
        +'&s_property='+escape(property).replace(/\+/g,'%2B')
//        +'&from='+escape(from).replace(/\+/g,'%2B')
        , true);
    xmlhttp.send(null);
}

function show_enquiriessearch_results() {
    try {
        if (xmlhttp.readyState==4){
            if (xmlhttp.status == 200) {
                _el('p1').innerHTML = "" + xmlhttp.responseText;
            } else {
                alert("There was a problem retrieving the XML data:\n" + xmlhttp.statusText);
            }
        }
    } catch(e) {alert("Exception!\n\n" + e.description);}
}


function statistic_do_qsearch(from){
    xmlhttp = initRequest();
    var monthyear = _el('s_monthyear').value;
    var property = _el('s_property').value;

    xmlhttp.onreadystatechange=show_statisticssearch_results;
    xmlhttp.open("GET", baseuri + '/account/statistics/qsearch/?'
        +'s_monthyear='+escape(monthyear).replace(/\+/g,'%2B')
        +'&s_property='+escape(property).replace(/\+/g,'%2B')
        , true);
    xmlhttp.send(null);
}

function show_statisticssearch_results() {
    try {
        if (xmlhttp.readyState==4){
            if (xmlhttp.status == 200) {
                _el('stat_table').innerHTML = xmlhttp.responseText;
            } else {
                alert("There was a problem retrieving the XML data:\n" + xmlhttp.statusText);
            }
        }
    } catch(e) {alert("Exception!\n\n" + e.description);}
}

function show_calendar(direction, mode, style) {
    xmlhttp = initRequest();

    var id_property = _el('calendar_id_property').value;
    var startYear = _el('calendar_startYear').value;
    var startMonth = _el('calendar_startMonth').value*1+direction;

    var url = ("edit"==mode) ? '/editcalendar/?' : '/calendar/?';

    if (startMonth<=0) {
        startMonth = 12-Math.abs(startMonth);
        startYear--;
    }

    if (startMonth==13) {
        startMonth = 1;
        startYear++;
    }

    xmlhttp.onreadystatechange=show_calendar_results;
    xmlhttp.open("GET", baseuri + url
        +'id='+escape(id_property).replace(/\+/g,'%2B')
        +'&startYear='+escape(startYear).replace(/\+/g,'%2B')
        +'&startMonth='+escape(startMonth).replace(/\+/g,'%2B')
        +'&style='+escape(style).replace(/\+/g,'%2B')
        , true);

    xmlhttp.send(null);
}

function show_edit_calendar(direction) {

    var id_property = _el('calendar_id_property').value;
    var startYear = _el('calendar_startYear').value;
    var startMonth = _el('calendar_startMonth').value*1+direction;

    var setdate =  (arguments.length>1)?arguments[1]:'';

    if (startMonth==0) {
        startMonth = 12;
        startYear--;
    }

    if (startMonth==13) {
        startMonth = 1;
        startYear++;
    }
    
    xmlhttp = initRequest();
    xmlhttp.onreadystatechange= function() {
        if (xmlhttp.readyState==4){
            if (xmlhttp.status == 200) {
                var r, re;
                var s = xmlhttp.responseText;
                var re_re = new RegExp("<script(.*?)>","ig");
                s = s.replace(re_re,"");
                re_re = new RegExp("</script>","ig");
                s = s.replace(re_re,"");
                if(s != ""){
                    eval(s);
                }
            } else {
                alert("There was a problem retrieving the XML data:\n" + xmlhttp_form.statusText);
            }
        }
    };
    xmlhttp.open("GET", baseuri + '/editcalendar/setdate?'
        +'id='+escape(id_property).replace(/\+/g,'%2B')
        //+'&startYear='+escape(startYear).replace(/\+/g,'%2B')
        //+'&startMonth='+escape(startMonth).replace(/\+/g,'%2B')
        +'&setdate='+escape(setdate).replace(/\+/g,'%2B')
        , true);

    xmlhttp.send(null);
}


function show_calendar_results() {
    if (xmlhttp.readyState==4){
        if (xmlhttp.status == 200) {
            _el('calendar').innerHTML = xmlhttp.responseText;
        } else {
            alert("There was a problem retrieving the XML data:\n" + xmlhttp.statusText);
        }
    }
}

function edit_calendar() {

    var id_property = _el('calendar_id_property').value;
    var setaction = _el('setaction').value;

    var startday = _el('startday').value;
    var startmonthyear = _el('startmonthyear').value;
    var endday = _el('endday').value;
    var endmonthyear = _el('endmonthyear').value;

    xmlhttp = initRequest();
    xmlhttp.onreadystatechange = function (){

        if (xmlhttp.readyState==4){
            if (xmlhttp.status == 200) {
                //show_calendar(0, 'edit');

                //var r, re;
                var s = xmlhttp.responseText;
                /*
                var re_re = new RegExp("<script(.*?)>","ig");
                s = s.replace(re_re,"");
                re_re = new RegExp("</script>","ig");
                s = s.replace(re_re,"");
                */
                if( "SUCCESS" == s.stripScripts().strip() ){
/*                    var ym = startmonthyear.split("-");
                    var dtStart = new Date( ym[0], ym[1]-1, startday );
                    //alert(dtStart.getFullYear()+'-'+formatDateStr(dtStart.getMonth()+1)+'-'+formatDateStr(dtStart.getDate()));
                    ym = endmonthyear.split("-");
                    var dtEnd = new Date( ym[0], ym[1]-1, endday );
                    //alert(dtEnd);

                    while( dtStart <= dtEnd ) {
                        _el('d_'+dtStart.getFullYear()+'-'+formatDateStr(dtStart.getMonth()+1)+'-'+formatDateStr(dtStart.getDate())).className=setaction;
                        dtStart.setDate( dtStart.getDate()+1 );
                    }
*/
                }
                s.evalScripts();

            } else {
                alert("There was a problem retrieving the XML data:\n" + xmlhttp.statusText);
            }
        }
    }
    var params = 'id='+escape(id_property).replace(/\+/g,'%2B')
        +'&startday='+escape(startday).replace(/\+/g,'%2B')
        +'&startmonthyear='+escape(startmonthyear).replace(/\+/g,'%2B')
        +'&endday='+escape(endday).replace(/\+/g,'%2B')
        +'&endmonthyear='+escape(endmonthyear).replace(/\+/g,'%2B')
        +'&setaction='+escape(setaction).replace(/\+/g,'%B')
        +'&ajax=1';

    xmlhttp.open("POST", baseuri + '/forms/users/properties/edit/calendar/do', true);
    xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
    xmlhttp.setRequestHeader("Content-length", params.length);
    xmlhttp.setRequestHeader("Connection", "close");

    xmlhttp.send( params );
/*
    xmlhttp.open("GET", baseuri + '/editcalendar/setrange?'
        +'id='+escape(id_property).replace(/\+/g,'%2B')
        +'&startday='+escape(startday).replace(/\+/g,'%2B')
        +'&startmonthyear='+escape(startmonthyear).replace(/\+/g,'%2B')
        +'&endday='+escape(endday).replace(/\+/g,'%2B')
        +'&endmonthyear='+escape(endmonthyear).replace(/\+/g,'%2B')
        +'&setaction='+escape(setaction).replace(/\+/g,'%2B')
        , true);

    xmlhttp.send(null);
*/
//    show_calendar(0, 'edit');
}

function formatDateStr(d) {
    return ( d.toString().length < 2 ) ? '0'+d : d;
}

var iex     = (document.all);
var nav     = (document.layers);
var old     = (navigator.appName=="Netscape" && !document.layers && !document.getElementById);
var n_6     = (window.sidebar);
var popup_price_id    = "popup_price";
var c_popup     = -1;
var last_obj    = 0;
var overpopup   = 0;
//var last_obj_class = '';

function show_price_popup(e,obj,price_position_id) {

    if (!price_position_id) return;

    c_popup = obj;
    var x = y = 0;
    var tag = obj;
    while (tag.tagName!="BODY") {
        y+=tag.offsetTop;
        x+=tag.offsetLeft;
        tag=tag.offsetParent;
    }

    if (!iex) {
        x=e.pageX;
        y=e.pageY;
    } else {
        x=e.x;
        y=e.y + document.body.scrollTop;
    }

    var popup = _el(popup_price_id);
    y += 35;
    x += 15;

//    _el('content_price').innerHTML = popup_html;
    _el('content_price').innerHTML = PricePeriods[price_position_id].price_weekly[0]+' '+PricePeriods[price_position_id].price_weekly[1];
//    _el('content_description').innerHTML = PricePeriods[price_position_id].description;
    popup.style.top = y+'px';
    popup.style.left = x+'px';
    popup.style.visibility = "visible";
    obj.blur();
    e.cancelBubble=true;
    last_obj = obj;

    return true;
}

function move_price_popup(e) {
    if (last_obj != '0') {
        var popup = _el(popup_price_id);
        if (!iex) {
            x=e.pageX;
            y=e.pageY;
        } else {
            x=e.x;
            y=e.y + document.body.scrollTop;
        }
        popup.style.top = (y+35)+'px';
        popup.style.left = (x+15)+'px';
    }
}
function hide_price_popup() {

    if (last_obj!=0) {
        last_obj.blur();
    }
    var popup = document.getElementById(popup_price_id);
    popup.style.top = '0px';
    popup.style.left = '0px';
    popup.style.visibility = "hidden";
    c_popup = -1;
    last_obj= 0;
    overpopup = 0;

    return true;
}



function edit_price_period(period_position_id){

    for (i=0; i<_el('startmonthyear_price').options.length;i++) {
        if (_el('startmonthyear_price').options[i].value == PricePeriods[period_position_id].date[0].getFullYear()+'-'+((PricePeriods[period_position_id].date[0].getMonth().toString().length ==1?'0'+(PricePeriods[period_position_id].date[0].getMonth()+1):(PricePeriods[period_position_id].date[0].getMonth()+1)))) {
            _el('startmonthyear_price').selectedIndex = i;
        }
    }

    for (i=0; i<_el('endmonthyear_price').options.length;i++) {
        if (_el('endmonthyear_price').options[i].value == PricePeriods[period_position_id].date[1].getFullYear()+'-'+((PricePeriods[period_position_id].date[1].getMonth().toString().length ==1?'0'+(PricePeriods[period_position_id].date[1].getMonth()+1):(PricePeriods[period_position_id].date[1].getMonth()+1)))) {
            _el('endmonthyear_price').selectedIndex = i;
        }
    }
//    _el('submit_prices').value='Update';
//    _el('id_price_period').value=PricePeriods[period_position_id].id;
//    _el('description').value=PricePeriods[period_position_id].description;
    _el('price_weekly').value=PricePeriods[period_position_id].price_weekly[1];
    _el('startday_price').selectedIndex=PricePeriods[period_position_id].date[0].getDate()-1;
    _el('endday_price').selectedIndex=PricePeriods[period_position_id].date[1].getDate()-1;
}

function findChild (element, containerTag) {
    if (element && element.hasChildNodes)
      for (var i = 0; i < element.childNodes.length; ++i)
        if (element.childNodes[i].tagName == containerTag)
          return element.childNodes[i];
  
    return null;
}

function markPricePeriod(period_position_id) {

    var startDate = new Date( PricePeriods[period_position_id].date[0]);
    var endDate = new Date( PricePeriods[period_position_id].date[1]);
    var date_now = new Date;
    var k=0;

    if (_el('mark_'+period_position_id).checked) var action = 'Element.addClassName( findChild(td, \'DIV\'), \'hover\' );';
    else var action = 'Element.removeClassName( findChild(td, \'DIV\'), \'hover\' );';

    while (startDate <= endDate) {
        if (startDate.getFullYear()+'-'+formatDateStr(startDate.getMonth()+1)+'-'+formatDateStr(startDate.getDate()) < date_now.getFullYear()+'-'+formatDateStr(date_now.getMonth()+1)+'-'+formatDateStr(date_now.getDate())) {
            startDate.setDate( startDate.getDate()+1 );
            continue;
        }
        td = _el('d_'+startDate.getFullYear()+'-'+formatDateStr(startDate.getMonth()+1)+'-'+formatDateStr(startDate.getDate()));
        eval(action);
        startDate.setDate( startDate.getDate()+1 );
        k++;
    }

}


var textChanged = false;

function changeCheck(msg){
  if(textChanged){
    return confirm(msg);
  }else{
    return true;
  }
}

function initChangeCheck(msg){
    if(!document.getElementById){ return false; }
    // add change check for links
    var links = document.getElementsByTagName('a');
    for(var i=0; i < links.length; i++){
        if(links[i].className.indexOf('JSnocheck') == -1){
            links[i].onclick = function(){return changeCheck(msg);};
            links[i].onkeypress = function(){return changeCheck(msg);};
        }
    }

    var forms = document.forms;
    for(i=0; i < forms.length; i++){
        for(var k = 0;k < forms[i].elements.length;k++){
            if (forms[i].elements[k].className.indexOf('JSnocheck') == -1) {
                _addEventListener(forms[i].elements[k], "change", function(){textChanged = true;});
                _addEventListener(forms[i].elements[k], "keypress", function(){textChanged = true;});
            }
        }
    }
}

var iex     = (document.all);
var nav     = (document.layers);
var old     = (navigator.appName=="Netscape" && !document.layers && !document.getElementById);
var n_6     = (window.sidebar);
var popup_id    = "popup";
var c_popup     = -1;
var last_obj    = 0;
var overpopup   = 0;

function show_popup(e,obj,text,width,height) {
    c_popup = obj;
    var x = y = 0;
    var tag = obj;
    while (tag.tagName!="BODY") {
        y+=tag.offsetTop;
        x+=tag.offsetLeft;
        tag=tag.offsetParent;
    }

    if (!iex) {
        x=e.pageX;
        y=e.pageY;
    } else {
        x=e.x;
        y=e.y + document.body.scrollTop;
    }

    var popup = _el(popup_id);
    y += 16;

    popup.innerHTML = '<div style="width:'+width+'px;'+((height!=0)?'height:'+height+'px;':'')+'" class="popup">'+text+'</div>';
    popup.style.top = y+'px';
    popup.style.left = x+'px';
    popup.style.visibility = "visible";
    obj.blur();
    last_obj = obj;
    e.cancelBubble=true;
    return true;
}

function hidepopup() {
    if (last_obj!=0) {
        last_obj.blur();
    }
    var popup = document.getElementById(popup_id);
    popup.style.visibility = "hidden";
    c_popup = -1;
    last_obj= 0;
    overpopup = 0;
    return true;
}

function _el(id){
    return document.getElementById(id);
}

function setElVisibility(id,status) {
    _el(id).style.display = (status)?'':'none';
}
function showHide(id) {
    _el(id).style.display = (_el(id).style.display=='none')?'':'none';
    return false;
}

var dog = '@';

function m(){document.location='mailto'+':'+'support'+dog+'rentalsfrance.com'; return false;}

function pagePopUp(name, url, w, h) {
    self.open( url, name, "'status=no,scrollbars=yes,toolbar=yes,resizable=yes,menubar=yes,width="+w+",height="+h );
}

var __oldWOnLoad = window.onload;
window.onload = function() {
    var btn_elements = document.getElementsByTagName('input');
    for (var i=0; i<btn_elements.length; i++) {
        if ( "button" == btn_elements[i].type || "submit" == btn_elements[i].type || "reset" == btn_elements[i].type ) {
            _addEventListener(btn_elements[i], "mousedown", function(e) {
                if ( 'msie' != ua ) {
                    var o = e.currentTarget || e.srcElement;
                    if ( o.pushed ) { return; }
                    o.pushed = true;

                    o.style.borderStyle = "inset";
                    o.style.paddingTop = "1px;";
                    o.style.paddingLeft = "2px;";
                }
            });
            
            _addEventListener(btn_elements[i], "mouseup", function(e) {
                var o = e.currentTarget || e.srcElement;
                if ( 'msie' != ua ) {
                    if ( !o.pushed ) { return; }
                    o.pushed = false;
                    o.style.borderStyle = "";
                    //o.style.borderStyle = "outset";
                    o.style.paddingTop = "2px;";
                    o.style.paddingLeft = "3px;";
                }
                o.blur();
            });

            _addEventListener(btn_elements[i], "mouseout", function(e) {
                var o = e.currentTarget || e.srcElement;
                if ( 'msie' != ua ) {
                    if ( !o.pushed ) { return; }
                    o.pushed = false;
                    o.style.borderStyle = "";
                    //o.style.borderStyle = "outset";
                    o.style.paddingTop = "2px;";
                    o.style.paddingLeft = "3px;";
                }
                o.blur();
            });
        }
    }
   

    var a_elements = document.getElementsByTagName('a');
    for (var i=0; i<a_elements.length; i++) {
        _addEventListener(a_elements[i], "click", function(e){var o = e.currentTarget || e.srcElement; o.blur();});
    }

    if ( __oldWOnLoad ) { __oldWOnLoad(); }
}

function ajax_populate_select( s_id, who, w_id, is_search  ) {

    var is_search = is_search ? '&is_search=1' : '';
    var select_xmlhttp = initRequest();
    select_xmlhttp.onreadystatechange= function(el) {
        if (select_xmlhttp.readyState==4){
            if (select_xmlhttp.status == 200) {
               _el(s_id).innerHTML = select_xmlhttp.responseText;
            } else {
                alert("There was a problem retrieving the XML data:\n" + xmlhttp_form.statusText);
            }
        }
    };
    select_xmlhttp.open("GET", baseuri + "/selects/"+who+"?w_id=" + escape(w_id).replace(/\+/g,'%2B')+is_search, true);
    select_xmlhttp.send(null);
}


function swapNodes( node1, node2 ) {
    var parent = node1.parentNode;
    var tmpNode = node1.cloneNode(true);
    node2 = parent.replaceChild(tmpNode, node2);
    parent.replaceChild(node2, node1);
    parent.replaceChild(node1, tmpNode);
    tmpNode = null;
}


function onSelectChange(s_obj) {
    if ( s_obj[s_obj.selectedIndex].disabled ) {
        s_obj.selectedIndex = s_obj.prevIndex;
        return false;
    } else {
        s_obj.prevIndex = s_obj.selectedIndex;
        return true;
    }
}

function MultiSelector( list_target, max ){

    this.list_target = list_target;
    this.count = 0;
    this.id = 0;
    if( max ){
        this.max = max;
    } else {
        this.max = -1;
    };

    this.addElement = function( element ){

        // Make sure it's a file input element
        if( element.tagName == 'INPUT' && element.type == 'file' ){

            // Element name -- what number am I?
            element.name = 'file' + this.id++;

            // Add reference to this object
            element.multi_selector = this;

            // What to do when a file is selected
            element.onchange = function(){

                // New file input
                var new_element = document.createElement( 'input' );
                new_element.type = 'file';

                // Add new element
                this.parentNode.insertBefore( new_element, this );

                // Apply 'update' to element
                this.multi_selector.addElement( new_element );

                // Update list
                this.multi_selector.addListRow( this );

                // Hide this: we can't use display:none because Safari doesn't like it
                this.style.position = 'absolute';
                this.style.left = '-1000px';

            };
            // If we've reached maximum number, disable input element
            if( this.max != -1 && this.count >= this.max ){
                element.disabled = true;
            };

            // File element counter
            this.count++;
            // Most recent element
            this.current_element = element;

        } else {
            // This can only be applied to file input elements!
            alert( 'Error: not a file input element' );
        };

    };

    /**
     * Add a new row to the list of files
     */
    this.addListRow = function( element ){

        // Delete button
        var del_button = document.createElement( 'img' );
        del_button.alt = 'Delete';
        del_button.title = 'Delete';
        del_button.src = baseuri + '/img/ico/del.png';
        del_button.style.cursor = "pointer";
        del_button.element = element;

        var new_row_title   = document.createElement( 'input' );
        new_row_title.type  = 'text';
        new_row_title.value = '';
        new_row_title.name  = 'title'+(this.count-2);

        // Delete function
        del_button.onclick= function(){

            // Remove element from form
            this.element.parentNode.removeChild( this.element );

            // Remove this row from the list
            this.parentNode.parentNode.parentNode.removeChild( this.parentNode.parentNode );

            // Decrement counter
            this.element.multi_selector.count--;

            // Re-enable input element (if it's disabled)
            this.element.multi_selector.current_element.disabled = false;

            // Appease Safari
            //    without it Safari wants to reload the browser window
            //    which nixes your already queued uploads
            return false;
        };

        var tr = this.list_target.insertRow(this.count-1);
        var td = document.createElement('TD');
        td.appendChild(del_button);
        tr.appendChild(td);

        td = document.createElement('TD');
        var s = element.value;
        if(s.length > 35){
            s = '...' + s.substr(s.length-35);
        }
        td.innerHTML = s;
        tr.appendChild(td);

        td = document.createElement('TD');
        td.appendChild(new_row_title);
        tr.appendChild(td);

    };

};
/*  Prototype JavaScript framework, version 1.5.0_rc0
 *  (c) 2005 Sam Stephenson <sam@conio.net>
 *
 *  Prototype is freely distributable under the terms of an MIT-style license.
 *  For details, see the Prototype web site: http://prototype.conio.net/
 *
/*--------------------------------------------------------------------------*/

var Prototype = {
  Version: '1.5.0_rc0',
  ScriptFragment: '(?:<script.*?>)((\n|\r|.)*?)(?:<\/script>)',

  emptyFunction: function() {},
  K: function(x) {return x}
}

var Class = {
  create: function() {
    return function() {
      this.initialize.apply(this, arguments);
    }
  }
}

var Abstract = new Object();

Object.extend = function(destination, source) {
  for (var property in source) {
    destination[property] = source[property];
  }
  return destination;
}

Object.inspect = function(object) {
  try {
    if (object == undefined) return 'undefined';
    if (object == null) return 'null';
    return object.inspect ? object.inspect() : object.toString();
  } catch (e) {
    if (e instanceof RangeError) return '...';
    throw e;
  }
}

Function.prototype.bind = function() {
  var __method = this, args = $A(arguments), object = args.shift();
  return function() {
    return __method.apply(object, args.concat($A(arguments)));
  }
}

Function.prototype.bindAsEventListener = function(object) {
  var __method = this;
  return function(event) {
    return __method.call(object, event || window.event);
  }
}

Object.extend(Number.prototype, {
  toColorPart: function() {
    var digits = this.toString(16);
    if (this < 16) return '0' + digits;
    return digits;
  },

  succ: function() {
    return this + 1;
  },

  times: function(iterator) {
    $R(0, this, true).each(iterator);
    return this;
  }
});

var Try = {
  these: function() {
    var returnValue;

    for (var i = 0; i < arguments.length; i++) {
      var lambda = arguments[i];
      try {
        returnValue = lambda();
        break;
      } catch (e) {}
    }

    return returnValue;
  }
}

/*--------------------------------------------------------------------------*/

var PeriodicalExecuter = Class.create();
PeriodicalExecuter.prototype = {
  initialize: function(callback, frequency) {
    this.callback = callback;
    this.frequency = frequency;
    this.currentlyExecuting = false;

    this.registerCallback();
  },

  registerCallback: function() {
    setInterval(this.onTimerEvent.bind(this), this.frequency * 1000);
  },

  onTimerEvent: function() {
    if (!this.currentlyExecuting) {
      try {
        this.currentlyExecuting = true;
        this.callback();
      } finally {
        this.currentlyExecuting = false;
      }
    }
  }
}
Object.extend(String.prototype, {
  gsub: function(pattern, replacement) {
    var result = '', source = this, match;
    replacement = arguments.callee.prepareReplacement(replacement);

    while (source.length > 0) {
      if (match = source.match(pattern)) {
        result += source.slice(0, match.index);
        result += (replacement(match) || '').toString();
        source  = source.slice(match.index + match[0].length);
      } else {
        result += source, source = '';
      }
    }
    return result;
  },

  sub: function(pattern, replacement, count) {
    replacement = this.gsub.prepareReplacement(replacement);
    count = count === undefined ? 1 : count;

    return this.gsub(pattern, function(match) {
      if (--count < 0) return match[0];
      return replacement(match);
    });
  },

  scan: function(pattern, iterator) {
    this.gsub(pattern, iterator);
    return this;
  },

  truncate: function(length, truncation) {
    length = length || 30;
    truncation = truncation === undefined ? '...' : truncation;
    return this.length > length ?
      this.slice(0, length - truncation.length) + truncation : this;
  },

  strip: function() {
    return this.replace(/^\s+/, '').replace(/\s+$/, '');
  },

  stripTags: function() {
    return this.replace(/<\/?[^>]+>/gi, '');
  },

  stripScripts: function() {
    return this.replace(new RegExp(Prototype.ScriptFragment, 'img'), '');
  },

  extractScripts: function() {
    var matchAll = new RegExp(Prototype.ScriptFragment, 'img');
    var matchOne = new RegExp(Prototype.ScriptFragment, 'im');
    return (this.match(matchAll) || []).map(function(scriptTag) {
      return (scriptTag.match(matchOne) || ['', ''])[1];
    });
  },

  evalScripts: function() {
    return this.extractScripts().map(function(script) { return eval(script) });
  },

  escapeHTML: function() {
    var div = document.createElement('div');
    var text = document.createTextNode(this);
    div.appendChild(text);
    return div.innerHTML;
  },

  unescapeHTML: function() {
    var div = document.createElement('div');
    div.innerHTML = this.stripTags();
    return div.childNodes[0] ? div.childNodes[0].nodeValue : '';
  },

  toQueryParams: function() {
    var pairs = this.match(/^\??(.*)$/)[1].split('&');
    return pairs.inject({}, function(params, pairString) {
      var pair = pairString.split('=');
      params[pair[0]] = pair[1];
      return params;
    });
  },

  toArray: function() {
    return this.split('');
  },

  camelize: function() {
    var oStringList = this.split('-');
    if (oStringList.length == 1) return oStringList[0];

    var camelizedString = this.indexOf('-') == 0
      ? oStringList[0].charAt(0).toUpperCase() + oStringList[0].substring(1)
      : oStringList[0];

    for (var i = 1, len = oStringList.length; i < len; i++) {
      var s = oStringList[i];
      camelizedString += s.charAt(0).toUpperCase() + s.substring(1);
    }

    return camelizedString;
  },

  inspect: function() {
    return "'" + this.replace(/\\/g, '\\\\').replace(/'/g, '\\\'') + "'";
  }
});

String.prototype.gsub.prepareReplacement = function(replacement) {
  if (typeof replacement == 'function') return replacement;
  var template = new Template(replacement);
  return function(match) { return template.evaluate(match) };
}

String.prototype.parseQuery = String.prototype.toQueryParams;

var Template = Class.create();
Template.Pattern = /(^|.|\r|\n)(#\{(.*?)\})/;
Template.prototype = {
  initialize: function(template, pattern) {
    this.template = template.toString();
    this.pattern  = pattern || Template.Pattern;
  },

  evaluate: function(object) {
    return this.template.gsub(this.pattern, function(match) {
      var before = match[1];
      if (before == '\\') return match[2];
      return before + (object[match[3]] || '').toString();
    });
  }
}

var $break    = new Object();
var $continue = new Object();

var Enumerable = {
  each: function(iterator) {
    var index = 0;
    try {
      this._each(function(value) {
        try {
          iterator(value, index++);
        } catch (e) {
          if (e != $continue) throw e;
        }
      });
    } catch (e) {
      if (e != $break) throw e;
    }
  },

  all: function(iterator) {
    var result = true;
    this.each(function(value, index) {
      result = result && !!(iterator || Prototype.K)(value, index);
      if (!result) throw $break;
    });
    return result;
  },

  any: function(iterator) {
    var result = true;
    this.each(function(value, index) {
      if (result = !!(iterator || Prototype.K)(value, index))
        throw $break;
    });
    return result;
  },

  collect: function(iterator) {
    var results = [];
    this.each(function(value, index) {
      results.push(iterator(value, index));
    });
    return results;
  },

  detect: function (iterator) {
    var result;
    this.each(function(value, index) {
      if (iterator(value, index)) {
        result = value;
        throw $break;
      }
    });
    return result;
  },

  findAll: function(iterator) {
    var results = [];
    this.each(function(value, index) {
      if (iterator(value, index))
        results.push(value);
    });
    return results;
  },

  grep: function(pattern, iterator) {
    var results = [];
    this.each(function(value, index) {
      var stringValue = value.toString();
      if (stringValue.match(pattern))
        results.push((iterator || Prototype.K)(value, index));
    })
    return results;
  },

  include: function(object) {
    var found = false;
    this.each(function(value) {
      if (value == object) {
        found = true;
        throw $break;
      }
    });
    return found;
  },

  inject: function(memo, iterator) {
    this.each(function(value, index) {
      memo = iterator(memo, value, index);
    });
    return memo;
  },

  invoke: function(method) {
    var args = $A(arguments).slice(1);
    return this.collect(function(value) {
      return value[method].apply(value, args);
    });
  },

  max: function(iterator) {
    var result;
    this.each(function(value, index) {
      value = (iterator || Prototype.K)(value, index);
      if (result == undefined || value >= result)
        result = value;
    });
    return result;
  },

  min: function(iterator) {
    var result;
    this.each(function(value, index) {
      value = (iterator || Prototype.K)(value, index);
      if (result == undefined || value < result)
        result = value;
    });
    return result;
  },

  partition: function(iterator) {
    var trues = [], falses = [];
    this.each(function(value, index) {
      ((iterator || Prototype.K)(value, index) ?
        trues : falses).push(value);
    });
    return [trues, falses];
  },

  pluck: function(property) {
    var results = [];
    this.each(function(value, index) {
      results.push(value[property]);
    });
    return results;
  },

  reject: function(iterator) {
    var results = [];
    this.each(function(value, index) {
      if (!iterator(value, index))
        results.push(value);
    });
    return results;
  },

  sortBy: function(iterator) {
    return this.collect(function(value, index) {
      return {value: value, criteria: iterator(value, index)};
    }).sort(function(left, right) {
      var a = left.criteria, b = right.criteria;
      return a < b ? -1 : a > b ? 1 : 0;
    }).pluck('value');
  },

  toArray: function() {
    return this.collect(Prototype.K);
  },

  zip: function() {
    var iterator = Prototype.K, args = $A(arguments);
    if (typeof args.last() == 'function')
      iterator = args.pop();

    var collections = [this].concat(args).map($A);
    return this.map(function(value, index) {
      return iterator(collections.pluck(index));
    });
  },

  inspect: function() {
    return '#<Enumerable:' + this.toArray().inspect() + '>';
  }
}

Object.extend(Enumerable, {
  map:     Enumerable.collect,
  find:    Enumerable.detect,
  select:  Enumerable.findAll,
  member:  Enumerable.include,
  entries: Enumerable.toArray
});
var $A = Array.from = function(iterable) {
  if (!iterable) return [];
  if (iterable.toArray) {
    return iterable.toArray();
  } else {
    var results = [];
    for (var i = 0; i < iterable.length; i++)
      results.push(iterable[i]);
    return results;
  }
}

Object.extend(Array.prototype, Enumerable);

if (!Array.prototype._reverse)
  Array.prototype._reverse = Array.prototype.reverse;

Object.extend(Array.prototype, {
  _each: function(iterator) {
    for (var i = 0; i < this.length; i++)
      iterator(this[i]);
  },

  clear: function() {
    this.length = 0;
    return this;
  },

  first: function() {
    return this[0];
  },

  last: function() {
    return this[this.length - 1];
  },

  compact: function() {
    return this.select(function(value) {
      return value != undefined || value != null;
    });
  },

  flatten: function() {
    return this.inject([], function(array, value) {
      return array.concat(value && value.constructor == Array ?
        value.flatten() : [value]);
    });
  },

  without: function() {
    var values = $A(arguments);
    return this.select(function(value) {
      return !values.include(value);
    });
  },

  indexOf: function(object) {
    for (var i = 0; i < this.length; i++)
      if (this[i] == object) return i;
    return -1;
  },

  reverse: function(inline) {
    return (inline !== false ? this : this.toArray())._reverse();
  },

  inspect: function() {
    return '[' + this.map(Object.inspect).join(', ') + ']';
  }
});
var Hash = {
  _each: function(iterator) {
    for (var key in this) {
      var value = this[key];
      if (typeof value == 'function') continue;

      var pair = [key, value];
      pair.key = key;
      pair.value = value;
      iterator(pair);
    }
  },

  keys: function() {
    return this.pluck('key');
  },

  values: function() {
    return this.pluck('value');
  },

  merge: function(hash) {
    return $H(hash).inject($H(this), function(mergedHash, pair) {
      mergedHash[pair.key] = pair.value;
      return mergedHash;
    });
  },

  toQueryString: function() {
    return this.map(function(pair) {
      return pair.map(encodeURIComponent).join('=');
    }).join('&');
  },

  inspect: function() {
    return '#<Hash:{' + this.map(function(pair) {
      return pair.map(Object.inspect).join(': ');
    }).join(', ') + '}>';
  }
}

function $H(object) {
  var hash = Object.extend({}, object || {});
  Object.extend(hash, Enumerable);
  Object.extend(hash, Hash);
  return hash;
}
ObjectRange = Class.create();
Object.extend(ObjectRange.prototype, Enumerable);
Object.extend(ObjectRange.prototype, {
  initialize: function(start, end, exclusive) {
    this.start = start;
    this.end = end;
    this.exclusive = exclusive;
  },

  _each: function(iterator) {
    var value = this.start;
    do {
      iterator(value);
      value = value.succ();
    } while (this.include(value));
  },

  include: function(value) {
    if (value < this.start)
      return false;
    if (this.exclusive)
      return value < this.end;
    return value <= this.end;
  }
});

var $R = function(start, end, exclusive) {
  return new ObjectRange(start, end, exclusive);
}

var Ajax = {
  getTransport: function() {
    return Try.these(
      function() {return new XMLHttpRequest()},
      function() {return new ActiveXObject('Msxml2.XMLHTTP')},
      function() {return new ActiveXObject('Microsoft.XMLHTTP')}
    ) || false;
  },

  activeRequestCount: 0
}

Ajax.Responders = {
  responders: [],

  _each: function(iterator) {
    this.responders._each(iterator);
  },

  register: function(responderToAdd) {
    if (!this.include(responderToAdd))
      this.responders.push(responderToAdd);
  },

  unregister: function(responderToRemove) {
    this.responders = this.responders.without(responderToRemove);
  },

  dispatch: function(callback, request, transport, json) {
    this.each(function(responder) {
      if (responder[callback] && typeof responder[callback] == 'function') {
        try {
          responder[callback].apply(responder, [request, transport, json]);
        } catch (e) {}
      }
    });
  }
};

Object.extend(Ajax.Responders, Enumerable);

Ajax.Responders.register({
  onCreate: function() {
    Ajax.activeRequestCount++;
  },

  onComplete: function() {
    Ajax.activeRequestCount--;
  }
});

Ajax.Base = function() {};
Ajax.Base.prototype = {
  setOptions: function(options) {
    this.options = {
      method:       'post',
      asynchronous: true,
      contentType:  'application/x-www-form-urlencoded',
      parameters:   ''
    }
    Object.extend(this.options, options || {});
  },

  responseIsSuccess: function() {
    return this.transport.status == undefined
        || this.transport.status == 0
        || (this.transport.status >= 200 && this.transport.status < 300);
  },

  responseIsFailure: function() {
    return !this.responseIsSuccess();
  }
}

Ajax.Request = Class.create();
Ajax.Request.Events =
  ['Uninitialized', 'Loading', 'Loaded', 'Interactive', 'Complete'];

Ajax.Request.prototype = Object.extend(new Ajax.Base(), {
  initialize: function(url, options) {
    this.transport = Ajax.getTransport();
    this.setOptions(options);
    this.request(url);
  },

  request: function(url) {
    var parameters = this.options.parameters || '';
    if (parameters.length > 0) parameters += '&_=';

    try {
      this.url = url;
      if (this.options.method == 'get' && parameters.length > 0)
        this.url += (this.url.match(/\?/) ? '&' : '?') + parameters;

      Ajax.Responders.dispatch('onCreate', this, this.transport);

      this.transport.open(this.options.method, this.url,
        this.options.asynchronous);

      if (this.options.asynchronous) {
        this.transport.onreadystatechange = this.onStateChange.bind(this);
        setTimeout((function() {this.respondToReadyState(1)}).bind(this), 10);
      }

      this.setRequestHeaders();

      var body = this.options.postBody ? this.options.postBody : parameters;
      this.transport.send(this.options.method == 'post' ? body : null);

    } catch (e) {
      this.dispatchException(e);
    }
  },

  setRequestHeaders: function() {
    var requestHeaders =
      ['X-Requested-With', 'XMLHttpRequest',
       'X-Prototype-Version', Prototype.Version,
       'Accept', 'text/javascript, text/html, application/xml, text/xml, */*'];

    if (this.options.method == 'post') {
      requestHeaders.push('Content-type', this.options.contentType);

      /* Force "Connection: close" for Mozilla browsers to work around
       * a bug where XMLHttpReqeuest sends an incorrect Content-length
       * header. See Mozilla Bugzilla #246651.
       */
      if (this.transport.overrideMimeType)
        requestHeaders.push('Connection', 'close');
    }

    if (this.options.requestHeaders)
      requestHeaders.push.apply(requestHeaders, this.options.requestHeaders);

    for (var i = 0; i < requestHeaders.length; i += 2)
      this.transport.setRequestHeader(requestHeaders[i], requestHeaders[i+1]);
  },

  onStateChange: function() {
    var readyState = this.transport.readyState;
    if (readyState != 1)
      this.respondToReadyState(this.transport.readyState);
  },

  header: function(name) {
    try {
      return this.transport.getResponseHeader(name);
    } catch (e) {}
  },

  evalJSON: function() {
    try {
      return eval('(' + this.header('X-JSON') + ')');
    } catch (e) {}
  },

  evalResponse: function() {
    try {
      return eval(this.transport.responseText);
    } catch (e) {
      this.dispatchException(e);
    }
  },

  respondToReadyState: function(readyState) {
    var event = Ajax.Request.Events[readyState];
    var transport = this.transport, json = this.evalJSON();

    if (event == 'Complete') {
      try {
        (this.options['on' + this.transport.status]
         || this.options['on' + (this.responseIsSuccess() ? 'Success' : 'Failure')]
         || Prototype.emptyFunction)(transport, json);
      } catch (e) {
        this.dispatchException(e);
      }

      if ((this.header('Content-type') || '').match(/^text\/javascript/i))
        this.evalResponse();
    }

    try {
      (this.options['on' + event] || Prototype.emptyFunction)(transport, json);
      Ajax.Responders.dispatch('on' + event, this, transport, json);
    } catch (e) {
      this.dispatchException(e);
    }

    /* Avoid memory leak in MSIE: clean up the oncomplete event handler */
    if (event == 'Complete')
      this.transport.onreadystatechange = Prototype.emptyFunction;
  },

  dispatchException: function(exception) {
    (this.options.onException || Prototype.emptyFunction)(this, exception);
    Ajax.Responders.dispatch('onException', this, exception);
  }
});

Ajax.Updater = Class.create();

Object.extend(Object.extend(Ajax.Updater.prototype, Ajax.Request.prototype), {
  initialize: function(container, url, options) {
    this.containers = {
      success: container.success ? $(container.success) : $(container),
      failure: container.failure ? $(container.failure) :
        (container.success ? null : $(container))
    }

    this.transport = Ajax.getTransport();
    this.setOptions(options);

    var onComplete = this.options.onComplete || Prototype.emptyFunction;
    this.options.onComplete = (function(transport, object) {
      this.updateContent();
      onComplete(transport, object);
    }).bind(this);

    this.request(url);
  },

  updateContent: function() {
    var receiver = this.responseIsSuccess() ?
      this.containers.success : this.containers.failure;
    var response = this.transport.responseText;

    if (!this.options.evalScripts)
      response = response.stripScripts();

    if (receiver) {
      if (this.options.insertion) {
        new this.options.insertion(receiver, response);
      } else {
        Element.update(receiver, response);
      }
    }

    if (this.responseIsSuccess()) {
      if (this.onComplete)
        setTimeout(this.onComplete.bind(this), 10);
    }
  }
});

Ajax.PeriodicalUpdater = Class.create();
Ajax.PeriodicalUpdater.prototype = Object.extend(new Ajax.Base(), {
  initialize: function(container, url, options) {
    this.setOptions(options);
    this.onComplete = this.options.onComplete;

    this.frequency = (this.options.frequency || 2);
    this.decay = (this.options.decay || 1);

    this.updater = {};
    this.container = container;
    this.url = url;

    this.start();
  },

  start: function() {
    this.options.onComplete = this.updateComplete.bind(this);
    this.onTimerEvent();
  },

  stop: function() {
    this.updater.onComplete = undefined;
    clearTimeout(this.timer);
    (this.onComplete || Prototype.emptyFunction).apply(this, arguments);
  },

  updateComplete: function(request) {
    if (this.options.decay) {
      this.decay = (request.responseText == this.lastText ?
        this.decay * this.options.decay : 1);

      this.lastText = request.responseText;
    }
    this.timer = setTimeout(this.onTimerEvent.bind(this),
      this.decay * this.frequency * 1000);
  },

  onTimerEvent: function() {
    this.updater = new Ajax.Updater(this.container, this.url, this.options);
  }
});
function $() {
  var results = [], element;
  for (var i = 0; i < arguments.length; i++) {
    element = arguments[i];
    if (typeof element == 'string')
      element = document.getElementById(element);
    results.push(Element.extend(element));
  }
  return results.length < 2 ? results[0] : results;
}

document.getElementsByClassName = function(className, parentElement) {
  var children = ($(parentElement) || document.body).getElementsByTagName('*');
  return $A(children).inject([], function(elements, child) {
    if (child.className.match(new RegExp("(^|\\s)" + className + "(\\s|$)")))
      elements.push(Element.extend(child));
    return elements;
  });
}

/*--------------------------------------------------------------------------*/

if (!window.Element)
  var Element = new Object();

Element.extend = function(element) {
  if (!element) return;
  if (_nativeExtensions) return element;

  if (!element._extended && element.tagName && element != window) {
    var methods = Element.Methods, cache = Element.extend.cache;
    for (property in methods) {
      var value = methods[property];
      if (typeof value == 'function')
        element[property] = cache.findOrStore(value);
    }
  }

  element._extended = true;
  return element;
}

Element.extend.cache = {
  findOrStore: function(value) {
    return this[value] = this[value] || function() {
      return value.apply(null, [this].concat($A(arguments)));
    }
  }
}

Element.Methods = {
  visible: function(element) {
    return $(element).style.display != 'none';
  },

  toggle: function() {
    for (var i = 0; i < arguments.length; i++) {
      var element = $(arguments[i]);
      Element[Element.visible(element) ? 'hide' : 'show'](element);
    }
  },

  hide: function() {
    for (var i = 0; i < arguments.length; i++) {
      var element = $(arguments[i]);
      element.style.display = 'none';
    }
  },

  show: function() {
    for (var i = 0; i < arguments.length; i++) {
      var element = $(arguments[i]);
      element.style.display = '';
    }
  },

  remove: function(element) {
    element = $(element);
    element.parentNode.removeChild(element);
  },

  update: function(element, html) {
    $(element).innerHTML = html.stripScripts();
    setTimeout(function() {html.evalScripts()}, 10);
  },

  replace: function(element, html) {
    element = $(element);
    if (element.outerHTML) {
      element.outerHTML = html.stripScripts();
    } else {
      var range = element.ownerDocument.createRange();
      range.selectNodeContents(element);
      element.parentNode.replaceChild(
        range.createContextualFragment(html.stripScripts()), element);
    }
    setTimeout(function() {html.evalScripts()}, 10);
  },

  getHeight: function(element) {
    element = $(element);
    return element.offsetHeight;
  },

  classNames: function(element) {
    return new Element.ClassNames(element);
  },

  hasClassName: function(element, className) {
    if (!(element = $(element))) return;
    return Element.classNames(element).include(className);
  },

  addClassName: function(element, className) {
    if (!(element = $(element))) return;
    return Element.classNames(element).add(className);
  },

  removeClassName: function(element, className) {
    if (!(element = $(element))) return;
    return Element.classNames(element).remove(className);
  },

  // removes whitespace-only text node children
  cleanWhitespace: function(element) {
    element = $(element);
    for (var i = 0; i < element.childNodes.length; i++) {
      var node = element.childNodes[i];
      if (node.nodeType == 3 && !/\S/.test(node.nodeValue))
        Element.remove(node);
    }
  },

  empty: function(element) {
    return $(element).innerHTML.match(/^\s*$/);
  },

  childOf: function(element, ancestor) {
    element = $(element), ancestor = $(ancestor);
    while (element = element.parentNode)
      if (element == ancestor) return true;
    return false;
  },

  scrollTo: function(element) {
    element = $(element);
    var x = element.x ? element.x : element.offsetLeft,
        y = element.y ? element.y : element.offsetTop;
    window.scrollTo(x, y);
  },

  getStyle: function(element, style) {
    element = $(element);
    var value = element.style[style.camelize()];
    if (!value) {
      if (document.defaultView && document.defaultView.getComputedStyle) {
        var css = document.defaultView.getComputedStyle(element, null);
        value = css ? css.getPropertyValue(style) : null;
      } else if (element.currentStyle) {
        value = element.currentStyle[style.camelize()];
      }
    }

    if (window.opera && ['left', 'top', 'right', 'bottom'].include(style))
      if (Element.getStyle(element, 'position') == 'static') value = 'auto';

    return value == 'auto' ? null : value;
  },

  setStyle: function(element, style) {
    element = $(element);
    for (var name in style)
      element.style[name.camelize()] = style[name];
  },

  getDimensions: function(element) {
    element = $(element);
    if (Element.getStyle(element, 'display') != 'none')
      return {width: element.offsetWidth, height: element.offsetHeight};

    // All *Width and *Height properties give 0 on elements with display none,
    // so enable the element temporarily
    var els = element.style;
    var originalVisibility = els.visibility;
    var originalPosition = els.position;
    els.visibility = 'hidden';
    els.position = 'absolute';
    els.display = '';
    var originalWidth = element.clientWidth;
    var originalHeight = element.clientHeight;
    els.display = 'none';
    els.position = originalPosition;
    els.visibility = originalVisibility;
    return {width: originalWidth, height: originalHeight};
  },

  makePositioned: function(element) {
    element = $(element);
    var pos = Element.getStyle(element, 'position');
    if (pos == 'static' || !pos) {
      element._madePositioned = true;
      element.style.position = 'relative';
      // Opera returns the offset relative to the positioning context, when an
      // element is position relative but top and left have not been defined
      if (window.opera) {
        element.style.top = 0;
        element.style.left = 0;
      }
    }
  },

  undoPositioned: function(element) {
    element = $(element);
    if (element._madePositioned) {
      element._madePositioned = undefined;
      element.style.position =
        element.style.top =
        element.style.left =
        element.style.bottom =
        element.style.right = '';
    }
  },

  makeClipping: function(element) {
    element = $(element);
    if (element._overflow) return;
    element._overflow = element.style.overflow;
    if ((Element.getStyle(element, 'overflow') || 'visible') != 'hidden')
      element.style.overflow = 'hidden';
  },

  undoClipping: function(element) {
    element = $(element);
    if (element._overflow) return;
    element.style.overflow = element._overflow;
    element._overflow = undefined;
  }
}

Object.extend(Element, Element.Methods);

var _nativeExtensions = false;

if(!HTMLElement && /Konqueror|Safari|KHTML/.test(navigator.userAgent)) {
  var HTMLElement = {}
  HTMLElement.prototype = document.createElement('div').__proto__;
}

Element.addMethods = function(methods) {
  Object.extend(Element.Methods, methods || {});

  if(typeof HTMLElement != 'undefined') {
    var methods = Element.Methods, cache = Element.extend.cache;
    for (property in methods) {
      var value = methods[property];
      if (typeof value == 'function')
        HTMLElement.prototype[property] = cache.findOrStore(value);
    }
    _nativeExtensions = true;
  }
}

Element.addMethods();

var Toggle = new Object();
Toggle.display = Element.toggle;

/*--------------------------------------------------------------------------*/

Abstract.Insertion = function(adjacency) {
  this.adjacency = adjacency;
}

Abstract.Insertion.prototype = {
  initialize: function(element, content) {
    this.element = $(element);
    this.content = content.stripScripts();

    if (this.adjacency && this.element.insertAdjacentHTML) {
      try {
        this.element.insertAdjacentHTML(this.adjacency, this.content);
      } catch (e) {
        var tagName = this.element.tagName.toLowerCase();
        if (tagName == 'tbody' || tagName == 'tr') {
          this.insertContent(this.contentFromAnonymousTable());
        } else {
          throw e;
        }
      }
    } else {
      this.range = this.element.ownerDocument.createRange();
      if (this.initializeRange) this.initializeRange();
      this.insertContent([this.range.createContextualFragment(this.content)]);
    }

    setTimeout(function() {content.evalScripts()}, 10);
  },

  contentFromAnonymousTable: function() {
    var div = document.createElement('div');
    div.innerHTML = '<table><tbody>' + this.content + '</tbody></table>';
    return $A(div.childNodes[0].childNodes[0].childNodes);
  }
}

var Insertion = new Object();

Insertion.Before = Class.create();
Insertion.Before.prototype = Object.extend(new Abstract.Insertion('beforeBegin'), {
  initializeRange: function() {
    this.range.setStartBefore(this.element);
  },

  insertContent: function(fragments) {
    fragments.each((function(fragment) {
      this.element.parentNode.insertBefore(fragment, this.element);
    }).bind(this));
  }
});

Insertion.Top = Class.create();
Insertion.Top.prototype = Object.extend(new Abstract.Insertion('afterBegin'), {
  initializeRange: function() {
    this.range.selectNodeContents(this.element);
    this.range.collapse(true);
  },

  insertContent: function(fragments) {
    fragments.reverse(false).each((function(fragment) {
      this.element.insertBefore(fragment, this.element.firstChild);
    }).bind(this));
  }
});

Insertion.Bottom = Class.create();
Insertion.Bottom.prototype = Object.extend(new Abstract.Insertion('beforeEnd'), {
  initializeRange: function() {
    this.range.selectNodeContents(this.element);
    this.range.collapse(this.element);
  },

  insertContent: function(fragments) {
    fragments.each((function(fragment) {
      this.element.appendChild(fragment);
    }).bind(this));
  }
});

Insertion.After = Class.create();
Insertion.After.prototype = Object.extend(new Abstract.Insertion('afterEnd'), {
  initializeRange: function() {
    this.range.setStartAfter(this.element);
  },

  insertContent: function(fragments) {
    fragments.each((function(fragment) {
      this.element.parentNode.insertBefore(fragment,
        this.element.nextSibling);
    }).bind(this));
  }
});

/*--------------------------------------------------------------------------*/

Element.ClassNames = Class.create();
Element.ClassNames.prototype = {
  initialize: function(element) {
    this.element = $(element);
  },

  _each: function(iterator) {
    this.element.className.split(/\s+/).select(function(name) {
      return name.length > 0;
    })._each(iterator);
  },

  set: function(className) {
    this.element.className = className;
  },

  add: function(classNameToAdd) {
    if (this.include(classNameToAdd)) return;
    this.set(this.toArray().concat(classNameToAdd).join(' '));
  },

  remove: function(classNameToRemove) {
    if (!this.include(classNameToRemove)) return;
    this.set(this.select(function(className) {
      return className != classNameToRemove;
    }).join(' '));
  },

  toString: function() {
    return this.toArray().join(' ');
  }
}

Object.extend(Element.ClassNames.prototype, Enumerable);
var Selector = Class.create();
Selector.prototype = {
  initialize: function(expression) {
    this.params = {classNames: []};
    this.expression = expression.toString().strip();
    this.parseExpression();
    this.compileMatcher();
  },

  parseExpression: function() {
    function abort(message) { throw 'Parse error in selector: ' + message; }

    if (this.expression == '')  abort('empty expression');

    var params = this.params, expr = this.expression, match, modifier, clause, rest;
    while (match = expr.match(/^(.*)\[([a-z0-9_:-]+?)(?:([~\|!]?=)(?:"([^"]*)"|([^\]\s]*)))?\]$/i)) {
      params.attributes = params.attributes || [];
      params.attributes.push({name: match[2], operator: match[3], value: match[4] || match[5] || ''});
      expr = match[1];
    }

    if (expr == '*') return this.params.wildcard = true;

    while (match = expr.match(/^([^a-z0-9_-])?([a-z0-9_-]+)(.*)/i)) {
      modifier = match[1], clause = match[2], rest = match[3];
      switch (modifier) {
        case '#':       params.id = clause; break;
        case '.':       params.classNames.push(clause); break;
        case '':
        case undefined: params.tagName = clause.toUpperCase(); break;
        default:        abort(expr.inspect());
      }
      expr = rest;
    }

    if (expr.length > 0) abort(expr.inspect());
  },

  buildMatchExpression: function() {
    var params = this.params, conditions = [], clause;

    if (params.wildcard)
      conditions.push('true');
    if (clause = params.id)
      conditions.push('element.id == ' + clause.inspect());
    if (clause = params.tagName)
      conditions.push('element.tagName.toUpperCase() == ' + clause.inspect());
    if ((clause = params.classNames).length > 0)
      for (var i = 0; i < clause.length; i++)
        conditions.push('Element.hasClassName(element, ' + clause[i].inspect() + ')');
    if (clause = params.attributes) {
      clause.each(function(attribute) {
        var value = 'element.getAttribute(' + attribute.name.inspect() + ')';
        var splitValueBy = function(delimiter) {
          return value + ' && ' + value + '.split(' + delimiter.inspect() + ')';
        }

        switch (attribute.operator) {
          case '=':       conditions.push(value + ' == ' + attribute.value.inspect()); break;
          case '~=':      conditions.push(splitValueBy(' ') + '.include(' + attribute.value.inspect() + ')'); break;
          case '|=':      conditions.push(
                            splitValueBy('-') + '.first().toUpperCase() == ' + attribute.value.toUpperCase().inspect()
                          ); break;
          case '!=':      conditions.push(value + ' != ' + attribute.value.inspect()); break;
          case '':
          case undefined: conditions.push(value + ' != null'); break;
          default:        throw 'Unknown operator ' + attribute.operator + ' in selector';
        }
      });
    }

    return conditions.join(' && ');
  },

  compileMatcher: function() {
    this.match = new Function('element', 'if (!element.tagName) return false; \
      return ' + this.buildMatchExpression());
  },

  findElements: function(scope) {
    var element;

    if (element = $(this.params.id))
      if (this.match(element))
        if (!scope || Element.childOf(element, scope))
          return [element];

    scope = (scope || document).getElementsByTagName(this.params.tagName || '*');

    var results = [];
    for (var i = 0; i < scope.length; i++)
      if (this.match(element = scope[i]))
        results.push(Element.extend(element));

    return results;
  },

  toString: function() {
    return this.expression;
  }
}

function $$() {
  return $A(arguments).map(function(expression) {
    return expression.strip().split(/\s+/).inject([null], function(results, expr) {
      var selector = new Selector(expr);
      return results.map(selector.findElements.bind(selector)).flatten();
    });
  }).flatten();
}
var Field = {
  clear: function() {
    for (var i = 0; i < arguments.length; i++)
      $(arguments[i]).value = '';
  },

  focus: function(element) {
    $(element).focus();
  },

  present: function() {
    for (var i = 0; i < arguments.length; i++)
      if ($(arguments[i]).value == '') return false;
    return true;
  },

  select: function(element) {
    $(element).select();
  },

  activate: function(element) {
    element = $(element);
    element.focus();
    if (element.select)
      element.select();
  }
}

/*--------------------------------------------------------------------------*/

var Form = {
  serialize: function(form) {
    var elements = Form.getElements($(form));
    var queryComponents = new Array();

    for (var i = 0; i < elements.length; i++) {
      var queryComponent = Form.Element.serialize(elements[i]);
      if (queryComponent)
        queryComponents.push(queryComponent);
    }

    return queryComponents.join('&');
  },

  getElements: function(form) {
    form = $(form);
    var elements = new Array();

    for (var tagName in Form.Element.Serializers) {
      var tagElements = form.getElementsByTagName(tagName);
      for (var j = 0; j < tagElements.length; j++)
        elements.push(tagElements[j]);
    }
    return elements;
  },

  getInputs: function(form, typeName, name) {
    form = $(form);
    var inputs = form.getElementsByTagName('input');

    if (!typeName && !name)
      return inputs;

    var matchingInputs = new Array();
    for (var i = 0; i < inputs.length; i++) {
      var input = inputs[i];
      if ((typeName && input.type != typeName) ||
          (name && input.name != name))
        continue;
      matchingInputs.push(input);
    }

    return matchingInputs;
  },

  disable: function(form) {
    var elements = Form.getElements(form);
    for (var i = 0; i < elements.length; i++) {
      var element = elements[i];
      element.blur();
      element.disabled = 'true';
    }
  },

  enable: function(form) {
    var elements = Form.getElements(form);
    for (var i = 0; i < elements.length; i++) {
      var element = elements[i];
      element.disabled = '';
    }
  },

  findFirstElement: function(form) {
    return Form.getElements(form).find(function(element) {
      return element.type != 'hidden' && !element.disabled &&
        ['input', 'select', 'textarea'].include(element.tagName.toLowerCase());
    });
  },

  focusFirstElement: function(form) {
    Field.activate(Form.findFirstElement(form));
  },

  reset: function(form) {
    $(form).reset();
  }
}

Form.Element = {
  serialize: function(element) {
    element = $(element);
    var method = element.tagName.toLowerCase();
    var parameter = Form.Element.Serializers[method](element);

    if (parameter) {
      var key = encodeURIComponent(parameter[0]);
      if (key.length == 0) return;

      if (parameter[1].constructor != Array)
        parameter[1] = [parameter[1]];

      return parameter[1].map(function(value) {
        return key + '=' + encodeURIComponent(value);
      }).join('&');
    }
  },

  getValue: function(element) {
    element = $(element);
    var method = element.tagName.toLowerCase();
    var parameter = Form.Element.Serializers[method](element);

    if (parameter)
      return parameter[1];
  }
}

Form.Element.Serializers = {
  input: function(element) {
    switch (element.type.toLowerCase()) {
      case 'submit':
      case 'hidden':
      case 'password':
      case 'text':
        return Form.Element.Serializers.textarea(element);
      case 'checkbox':
      case 'radio':
        return Form.Element.Serializers.inputSelector(element);
    }
    return false;
  },

  inputSelector: function(element) {
    if (element.checked)
      return [element.name, element.value];
  },

  textarea: function(element) {
    return [element.name, element.value];
  },

  select: function(element) {
    return Form.Element.Serializers[element.type == 'select-one' ?
      'selectOne' : 'selectMany'](element);
  },

  selectOne: function(element) {
    var value = '', opt, index = element.selectedIndex;
    if (index >= 0) {
      opt = element.options[index];
      value = opt.value || opt.text;
    }
    return [element.name, value];
  },

  selectMany: function(element) {
    var value = [];
    for (var i = 0; i < element.length; i++) {
      var opt = element.options[i];
      if (opt.selected)
        value.push(opt.value || opt.text);
    }
    return [element.name, value];
  }
}

/*--------------------------------------------------------------------------*/

var $F = Form.Element.getValue;

/*--------------------------------------------------------------------------*/

Abstract.TimedObserver = function() {}
Abstract.TimedObserver.prototype = {
  initialize: function(element, frequency, callback) {
    this.frequency = frequency;
    this.element   = $(element);
    this.callback  = callback;

    this.lastValue = this.getValue();
    this.registerCallback();
  },

  registerCallback: function() {
    setInterval(this.onTimerEvent.bind(this), this.frequency * 1000);
  },

  onTimerEvent: function() {
    var value = this.getValue();
    if (this.lastValue != value) {
      this.callback(this.element, value);
      this.lastValue = value;
    }
  }
}

Form.Element.Observer = Class.create();
Form.Element.Observer.prototype = Object.extend(new Abstract.TimedObserver(), {
  getValue: function() {
    return Form.Element.getValue(this.element);
  }
});

Form.Observer = Class.create();
Form.Observer.prototype = Object.extend(new Abstract.TimedObserver(), {
  getValue: function() {
    return Form.serialize(this.element);
  }
});

/*--------------------------------------------------------------------------*/

Abstract.EventObserver = function() {}
Abstract.EventObserver.prototype = {
  initialize: function(element, callback) {
    this.element  = $(element);
    this.callback = callback;

    this.lastValue = this.getValue();
    if (this.element.tagName.toLowerCase() == 'form')
      this.registerFormCallbacks();
    else
      this.registerCallback(this.element);
  },

  onElementEvent: function() {
    var value = this.getValue();
    if (this.lastValue != value) {
      this.callback(this.element, value);
      this.lastValue = value;
    }
  },

  registerFormCallbacks: function() {
    var elements = Form.getElements(this.element);
    for (var i = 0; i < elements.length; i++)
      this.registerCallback(elements[i]);
  },

  registerCallback: function(element) {
    if (element.type) {
      switch (element.type.toLowerCase()) {
        case 'checkbox':
        case 'radio':
          Event.observe(element, 'click', this.onElementEvent.bind(this));
          break;
        case 'password':
        case 'text':
        case 'textarea':
        case 'select-one':
        case 'select-multiple':
          Event.observe(element, 'change', this.onElementEvent.bind(this));
          break;
      }
    }
  }
}

Form.Element.EventObserver = Class.create();
Form.Element.EventObserver.prototype = Object.extend(new Abstract.EventObserver(), {
  getValue: function() {
    return Form.Element.getValue(this.element);
  }
});

Form.EventObserver = Class.create();
Form.EventObserver.prototype = Object.extend(new Abstract.EventObserver(), {
  getValue: function() {
    return Form.serialize(this.element);
  }
});
if (!window.Event) {
  var Event = new Object();
}

Object.extend(Event, {
  KEY_BACKSPACE: 8,
  KEY_TAB:       9,
  KEY_RETURN:   13,
  KEY_ESC:      27,
  KEY_LEFT:     37,
  KEY_UP:       38,
  KEY_RIGHT:    39,
  KEY_DOWN:     40,
  KEY_DELETE:   46,

  element: function(event) {
    return event.target || event.srcElement;
  },

  isLeftClick: function(event) {
    return (((event.which) && (event.which == 1)) ||
            ((event.button) && (event.button == 1)));
  },

  pointerX: function(event) {
    return event.pageX || (event.clientX +
      (document.documentElement.scrollLeft || document.body.scrollLeft));
  },

  pointerY: function(event) {
    return event.pageY || (event.clientY +
      (document.documentElement.scrollTop || document.body.scrollTop));
  },

  stop: function(event) {
    if (event.preventDefault) {
      event.preventDefault();
      event.stopPropagation();
    } else {
      event.returnValue = false;
      event.cancelBubble = true;
    }
  },

  // find the first node with the given tagName, starting from the
  // node the event was triggered on; traverses the DOM upwards
  findElement: function(event, tagName) {
    var element = Event.element(event);
    while (element.parentNode && (!element.tagName ||
        (element.tagName.toUpperCase() != tagName.toUpperCase())))
      element = element.parentNode;
    return element;
  },

  observers: false,

  _observeAndCache: function(element, name, observer, useCapture) {
    if (!this.observers) this.observers = [];
    if (element.addEventListener) {
      this.observers.push([element, name, observer, useCapture]);
      element.addEventListener(name, observer, useCapture);
    } else if (element.attachEvent) {
      this.observers.push([element, name, observer, useCapture]);
      element.attachEvent('on' + name, observer);
    }
  },

  unloadCache: function() {
    if (!Event.observers) return;
    for (var i = 0; i < Event.observers.length; i++) {
      Event.stopObserving.apply(this, Event.observers[i]);
      Event.observers[i][0] = null;
    }
    Event.observers = false;
  },

  observe: function(element, name, observer, useCapture) {
    var element = $(element);
    useCapture = useCapture || false;

    if (name == 'keypress' &&
        (navigator.appVersion.match(/Konqueror|Safari|KHTML/)
        || element.attachEvent))
      name = 'keydown';

    this._observeAndCache(element, name, observer, useCapture);
  },

  stopObserving: function(element, name, observer, useCapture) {
    var element = $(element);
    useCapture = useCapture || false;

    if (name == 'keypress' &&
        (navigator.appVersion.match(/Konqueror|Safari|KHTML/)
        || element.detachEvent))
      name = 'keydown';

    if (element.removeEventListener) {
      element.removeEventListener(name, observer, useCapture);
    } else if (element.detachEvent) {
      element.detachEvent('on' + name, observer);
    }
  }
});

/* prevent memory leaks in IE */
if (navigator.appVersion.match(/\bMSIE\b/))
  Event.observe(window, 'unload', Event.unloadCache, false);
var Position = {
  // set to true if needed, warning: firefox performance problems
  // NOT neeeded for page scrolling, only if draggable contained in
  // scrollable elements
  includeScrollOffsets: false,

  // must be called before calling withinIncludingScrolloffset, every time the
  // page is scrolled
  prepare: function() {
    this.deltaX =  window.pageXOffset
                || document.documentElement.scrollLeft
                || document.body.scrollLeft
                || 0;
    this.deltaY =  window.pageYOffset
                || document.documentElement.scrollTop
                || document.body.scrollTop
                || 0;
  },

  realOffset: function(element) {
    var valueT = 0, valueL = 0;
    do {
      valueT += element.scrollTop  || 0;
      valueL += element.scrollLeft || 0;
      element = element.parentNode;
    } while (element);
    return [valueL, valueT];
  },

  cumulativeOffset: function(element) {
    var valueT = 0, valueL = 0;
    do {
      valueT += element.offsetTop  || 0;
      valueL += element.offsetLeft || 0;
      element = element.offsetParent;
    } while (element);
    return [valueL, valueT];
  },

  positionedOffset: function(element) {
    var valueT = 0, valueL = 0;
    do {
      valueT += element.offsetTop  || 0;
      valueL += element.offsetLeft || 0;
      element = element.offsetParent;
      if (element) {
        p = Element.getStyle(element, 'position');
        if (p == 'relative' || p == 'absolute') break;
      }
    } while (element);
    return [valueL, valueT];
  },

  offsetParent: function(element) {
    if (element.offsetParent) return element.offsetParent;
    if (element == document.body) return element;

    while ((element = element.parentNode) && element != document.body)
      if (Element.getStyle(element, 'position') != 'static')
        return element;

    return document.body;
  },

  // caches x/y coordinate pair to use with overlap
  within: function(element, x, y) {
    if (this.includeScrollOffsets)
      return this.withinIncludingScrolloffsets(element, x, y);
    this.xcomp = x;
    this.ycomp = y;
    this.offset = this.cumulativeOffset(element);

    return (y >= this.offset[1] &&
            y <  this.offset[1] + element.offsetHeight &&
            x >= this.offset[0] &&
            x <  this.offset[0] + element.offsetWidth);
  },

  withinIncludingScrolloffsets: function(element, x, y) {
    var offsetcache = this.realOffset(element);

    this.xcomp = x + offsetcache[0] - this.deltaX;
    this.ycomp = y + offsetcache[1] - this.deltaY;
    this.offset = this.cumulativeOffset(element);

    return (this.ycomp >= this.offset[1] &&
            this.ycomp <  this.offset[1] + element.offsetHeight &&
            this.xcomp >= this.offset[0] &&
            this.xcomp <  this.offset[0] + element.offsetWidth);
  },

  // within must be called directly before
  overlap: function(mode, element) {
    if (!mode) return 0;
    if (mode == 'vertical')
      return ((this.offset[1] + element.offsetHeight) - this.ycomp) /
        element.offsetHeight;
    if (mode == 'horizontal')
      return ((this.offset[0] + element.offsetWidth) - this.xcomp) /
        element.offsetWidth;
  },

  clone: function(source, target) {
    source = $(source);
    target = $(target);
    target.style.position = 'absolute';
    var offsets = this.cumulativeOffset(source);
    target.style.top    = offsets[1] + 'px';
    target.style.left   = offsets[0] + 'px';
    target.style.width  = source.offsetWidth + 'px';
    target.style.height = source.offsetHeight + 'px';
  },

  page: function(forElement) {
    var valueT = 0, valueL = 0;

    var element = forElement;
    do {
      valueT += element.offsetTop  || 0;
      valueL += element.offsetLeft || 0;

      // Safari fix
      if (element.offsetParent==document.body)
        if (Element.getStyle(element,'position')=='absolute') break;

    } while (element = element.offsetParent);

    element = forElement;
    do {
      valueT -= element.scrollTop  || 0;
      valueL -= element.scrollLeft || 0;
    } while (element = element.parentNode);

    return [valueL, valueT];
  },

  clone: function(source, target) {
    var options = Object.extend({
      setLeft:    true,
      setTop:     true,
      setWidth:   true,
      setHeight:  true,
      offsetTop:  0,
      offsetLeft: 0
    }, arguments[2] || {})

    // find page position of source
    source = $(source);
    var p = Position.page(source);

    // find coordinate system to use
    target = $(target);
    var delta = [0, 0];
    var parent = null;
    // delta [0,0] will do fine with position: fixed elements,
    // position:absolute needs offsetParent deltas
    if (Element.getStyle(target,'position') == 'absolute') {
      parent = Position.offsetParent(target);
      delta = Position.page(parent);
    }

    // correct by body offsets (fixes Safari)
    if (parent == document.body) {
      delta[0] -= document.body.offsetLeft;
      delta[1] -= document.body.offsetTop;
    }

    // set position
    if(options.setLeft)   target.style.left  = (p[0] - delta[0] + options.offsetLeft) + 'px';
    if(options.setTop)    target.style.top   = (p[1] - delta[1] + options.offsetTop) + 'px';
    if(options.setWidth)  target.style.width = source.offsetWidth + 'px';
    if(options.setHeight) target.style.height = source.offsetHeight + 'px';
  },

  absolutize: function(element) {
    element = $(element);
    if (element.style.position == 'absolute') return;
    Position.prepare();

    var offsets = Position.positionedOffset(element);
    var top     = offsets[1];
    var left    = offsets[0];
    var width   = element.clientWidth;
    var height  = element.clientHeight;

    element._originalLeft   = left - parseFloat(element.style.left  || 0);
    element._originalTop    = top  - parseFloat(element.style.top || 0);
    element._originalWidth  = element.style.width;
    element._originalHeight = element.style.height;

    element.style.position = 'absolute';
    element.style.top    = top + 'px';;
    element.style.left   = left + 'px';;
    element.style.width  = width + 'px';;
    element.style.height = height + 'px';;
  },

  relativize: function(element) {
    element = $(element);
    if (element.style.position == 'relative') return;
    Position.prepare();

    element.style.position = 'relative';
    var top  = parseFloat(element.style.top  || 0) - (element._originalTop || 0);
    var left = parseFloat(element.style.left || 0) - (element._originalLeft || 0);

    element.style.top    = top + 'px';
    element.style.left   = left + 'px';
    element.style.height = element._originalHeight;
    element.style.width  = element._originalWidth;
  }
}

// Safari returns margins on body which is incorrect if the child is absolutely
// positioned.  For performance reasons, redefine Position.cumulativeOffset for
// KHTML/WebKit only.
if (/Konqueror|Safari|KHTML/.test(navigator.userAgent)) {
  Position.cumulativeOffset = function(element) {
    var valueT = 0, valueL = 0;
    do {
      valueT += element.offsetTop  || 0;
      valueL += element.offsetLeft || 0;
      if (element.offsetParent == document.body)
        if (Element.getStyle(element, 'position') == 'absolute') break;

      element = element.offsetParent;
    } while (element);

    return [valueL, valueT];
  }
}
// Copyright (c) 2005 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us)
// 
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
// 
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

var Scriptaculous = {
  Version: '1.6.1',
  require: function(libraryName) {
    // inserting via DOM fails in Safari 2.0, so brute force approach
    document.write('<script type="text/javascript" src="'+libraryName+'"></script>');
  },
  load: function() {
    if((typeof Prototype=='undefined') || 
       (typeof Element == 'undefined') || 
       (typeof Element.Methods=='undefined') ||
       parseFloat(Prototype.Version.split(".")[0] + "." +
                  Prototype.Version.split(".")[1]) < 1.5)
       throw("script.aculo.us requires the Prototype JavaScript framework >= 1.5.0");
    
    $A(document.getElementsByTagName("script")).findAll( function(s) {
      return (s.src && s.src.match(/scriptaculous\.js(\?.*)?$/))
    }).each( function(s) {
      var path = s.src.replace(/scriptaculous\.js(\?.*)?$/,'');
      var includes = s.src.match(/\?.*load=([a-z,]*)/);
      (includes ? includes[1] : 'builder,effects,dragdrop,controls,slider').split(',').each(
       function(include) { Scriptaculous.require(path+include+'.js') });
    });
  }
}

Scriptaculous.load();
// Copyright (c) 2005 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us)
// Contributors:
//  Justin Palmer (http://encytemedia.com/)
//  Mark Pilgrim (http://diveintomark.org/)
//  Martin Bialasinki
// 
// See scriptaculous.js for full license.  

// converts rgb() and #xxx to #xxxxxx format,  
// returns self (or first argument) if not convertable  
String.prototype.parseColor = function() {  
  var color = '#';  
  if(this.slice(0,4) == 'rgb(') {  
    var cols = this.slice(4,this.length-1).split(',');  
    var i=0; do { color += parseInt(cols[i]).toColorPart() } while (++i<3);  
  } else {  
    if(this.slice(0,1) == '#') {  
      if(this.length==4) for(var i=1;i<4;i++) color += (this.charAt(i) + this.charAt(i)).toLowerCase();  
      if(this.length==7) color = this.toLowerCase();  
    }  
  }  
  return(color.length==7 ? color : (arguments[0] || this));  
}

/*--------------------------------------------------------------------------*/

Element.collectTextNodes = function(element) {  
  return $A($(element).childNodes).collect( function(node) {
    return (node.nodeType==3 ? node.nodeValue : 
      (node.hasChildNodes() ? Element.collectTextNodes(node) : ''));
  }).flatten().join('');
}

Element.collectTextNodesIgnoreClass = function(element, className) {  
  return $A($(element).childNodes).collect( function(node) {
    return (node.nodeType==3 ? node.nodeValue : 
      ((node.hasChildNodes() && !Element.hasClassName(node,className)) ? 
        Element.collectTextNodesIgnoreClass(node, className) : ''));
  }).flatten().join('');
}

Element.setContentZoom = function(element, percent) {
  element = $(element);  
  Element.setStyle(element, {fontSize: (percent/100) + 'em'});   
  if(navigator.appVersion.indexOf('AppleWebKit')>0) window.scrollBy(0,0);
}

Element.getOpacity = function(element){  
  var opacity;
  if (opacity = Element.getStyle(element, 'opacity'))  
    return parseFloat(opacity);  
  if (opacity = (Element.getStyle(element, 'filter') || '').match(/alpha\(opacity=(.*)\)/))  
    if(opacity[1]) return parseFloat(opacity[1]) / 100;  
  return 1.0;  
}

Element.setOpacity = function(element, value){  
  element= $(element);  
  if (value == 1){
    Element.setStyle(element, { opacity: 
      (/Gecko/.test(navigator.userAgent) && !/Konqueror|Safari|KHTML/.test(navigator.userAgent)) ? 
      0.999999 : null });
    if(/MSIE/.test(navigator.userAgent))  
      Element.setStyle(element, {filter: Element.getStyle(element,'filter').replace(/alpha\([^\)]*\)/gi,'')});  
  } else {  
    if(value < 0.00001) value = 0;  
    Element.setStyle(element, {opacity: value});
    if(/MSIE/.test(navigator.userAgent))  
     Element.setStyle(element, 
       { filter: Element.getStyle(element,'filter').replace(/alpha\([^\)]*\)/gi,'') +
                 'alpha(opacity='+value*100+')' });  
  }
}  
 
Element.getInlineOpacity = function(element){  
  return $(element).style.opacity || '';
}  

Element.childrenWithClassName = function(element, className, findFirst) {
  var classNameRegExp = new RegExp("(^|\\s)" + className + "(\\s|$)");
  var results = $A($(element).getElementsByTagName('*'))[findFirst ? 'detect' : 'select']( function(c) { 
    return (c.className && c.className.match(classNameRegExp));
  });
  if(!results) results = [];
  return results;
}

Element.forceRerendering = function(element) {
  try {
    element = $(element);
    var n = document.createTextNode(' ');
    element.appendChild(n);
    element.removeChild(n);
  } catch(e) { }
};

/*--------------------------------------------------------------------------*/

Array.prototype.call = function() {
  var args = arguments;
  this.each(function(f){ f.apply(this, args) });
}

/*--------------------------------------------------------------------------*/

var Effect = {
  tagifyText: function(element) {
    var tagifyStyle = 'position:relative';
    if(/MSIE/.test(navigator.userAgent)) tagifyStyle += ';zoom:1';
    element = $(element);
    $A(element.childNodes).each( function(child) {
      if(child.nodeType==3) {
        child.nodeValue.toArray().each( function(character) {
          element.insertBefore(
            Builder.node('span',{style: tagifyStyle},
              character == ' ' ? String.fromCharCode(160) : character), 
              child);
        });
        Element.remove(child);
      }
    });
  },
  multiple: function(element, effect) {
    var elements;
    if(((typeof element == 'object') || 
        (typeof element == 'function')) && 
       (element.length))
      elements = element;
    else
      elements = $(element).childNodes;
      
    var options = Object.extend({
      speed: 0.1,
      delay: 0.0
    }, arguments[2] || {});
    var masterDelay = options.delay;

    $A(elements).each( function(element, index) {
      new effect(element, Object.extend(options, { delay: index * options.speed + masterDelay }));
    });
  },
  PAIRS: {
    'slide':  ['SlideDown','SlideUp'],
    'blind':  ['BlindDown','BlindUp'],
    'appear': ['Appear','Fade']
  },
  toggle: function(element, effect) {
    element = $(element);
    effect = (effect || 'appear').toLowerCase();
    var options = Object.extend({
      queue: { position:'end', scope:(element.id || 'global'), limit: 1 }
    }, arguments[2] || {});
    Effect[element.visible() ? 
      Effect.PAIRS[effect][1] : Effect.PAIRS[effect][0]](element, options);
  }
};

var Effect2 = Effect; // deprecated

/* ------------- transitions ------------- */

Effect.Transitions = {}

Effect.Transitions.linear = function(pos) {
  return pos;
}
Effect.Transitions.sinoidal = function(pos) {
  return (-Math.cos(pos*Math.PI)/2) + 0.5;
}
Effect.Transitions.reverse  = function(pos) {
  return 1-pos;
}
Effect.Transitions.flicker = function(pos) {
  return ((-Math.cos(pos*Math.PI)/4) + 0.75) + Math.random()/4;
}
Effect.Transitions.wobble = function(pos) {
  return (-Math.cos(pos*Math.PI*(9*pos))/2) + 0.5;
}
Effect.Transitions.pulse = function(pos) {
  return (Math.floor(pos*10) % 2 == 0 ? 
    (pos*10-Math.floor(pos*10)) : 1-(pos*10-Math.floor(pos*10)));
}
Effect.Transitions.none = function(pos) {
  return 0;
}
Effect.Transitions.full = function(pos) {
  return 1;
}

/* ------------- core effects ------------- */

Effect.ScopedQueue = Class.create();
Object.extend(Object.extend(Effect.ScopedQueue.prototype, Enumerable), {
  initialize: function() {
    this.effects  = [];
    this.interval = null;
  },
  _each: function(iterator) {
    this.effects._each(iterator);
  },
  add: function(effect) {
    var timestamp = new Date().getTime();
    
    var position = (typeof effect.options.queue == 'string') ? 
      effect.options.queue : effect.options.queue.position;
    
    switch(position) {
      case 'front':
        // move unstarted effects after this effect  
        this.effects.findAll(function(e){ return e.state=='idle' }).each( function(e) {
            e.startOn  += effect.finishOn;
            e.finishOn += effect.finishOn;
          });
        break;
      case 'end':
        // start effect after last queued effect has finished
        timestamp = this.effects.pluck('finishOn').max() || timestamp;
        break;
    }
    
    effect.startOn  += timestamp;
    effect.finishOn += timestamp;

    if(!effect.options.queue.limit || (this.effects.length < effect.options.queue.limit))
      this.effects.push(effect);
    
    if(!this.interval) 
      this.interval = setInterval(this.loop.bind(this), 40);
  },
  remove: function(effect) {
    this.effects = this.effects.reject(function(e) { return e==effect });
    if(this.effects.length == 0) {
      clearInterval(this.interval);
      this.interval = null;
    }
  },
  loop: function() {
    var timePos = new Date().getTime();
    this.effects.invoke('loop', timePos);
  }
});

Effect.Queues = {
  instances: $H(),
  get: function(queueName) {
    if(typeof queueName != 'string') return queueName;
    
    if(!this.instances[queueName])
      this.instances[queueName] = new Effect.ScopedQueue();
      
    return this.instances[queueName];
  }
}
Effect.Queue = Effect.Queues.get('global');

Effect.DefaultOptions = {
  transition: Effect.Transitions.sinoidal,
  duration:   1.0,   // seconds
  fps:        25.0,  // max. 25fps due to Effect.Queue implementation
  sync:       false, // true for combining
  from:       0.0,
  to:         1.0,
  delay:      0.0,
  queue:      'parallel'
}

Effect.Base = function() {};
Effect.Base.prototype = {
  position: null,
  start: function(options) {
    this.options      = Object.extend(Object.extend({},Effect.DefaultOptions), options || {});
    this.currentFrame = 0;
    this.state        = 'idle';
    this.startOn      = this.options.delay*1000;
    this.finishOn     = this.startOn + (this.options.duration*1000);
    this.event('beforeStart');
    if(!this.options.sync)
      Effect.Queues.get(typeof this.options.queue == 'string' ? 
        'global' : this.options.queue.scope).add(this);
  },
  loop: function(timePos) {
    if(timePos >= this.startOn) {
      if(timePos >= this.finishOn) {
        this.render(1.0);
        this.cancel();
        this.event('beforeFinish');
        if(this.finish) this.finish(); 
        this.event('afterFinish');
        return;  
      }
      var pos   = (timePos - this.startOn) / (this.finishOn - this.startOn);
      var frame = Math.round(pos * this.options.fps * this.options.duration);
      if(frame > this.currentFrame) {
        this.render(pos);
        this.currentFrame = frame;
      }
    }
  },
  render: function(pos) {
    if(this.state == 'idle') {
      this.state = 'running';
      this.event('beforeSetup');
      if(this.setup) this.setup();
      this.event('afterSetup');
    }
    if(this.state == 'running') {
      if(this.options.transition) pos = this.options.transition(pos);
      pos *= (this.options.to-this.options.from);
      pos += this.options.from;
      this.position = pos;
      this.event('beforeUpdate');
      if(this.update) this.update(pos);
      this.event('afterUpdate');
    }
  },
  cancel: function() {
    if(!this.options.sync)
      Effect.Queues.get(typeof this.options.queue == 'string' ? 
        'global' : this.options.queue.scope).remove(this);
    this.state = 'finished';
  },
  event: function(eventName) {
    if(this.options[eventName + 'Internal']) this.options[eventName + 'Internal'](this);
    if(this.options[eventName]) this.options[eventName](this);
  },
  inspect: function() {
    return '#<Effect:' + $H(this).inspect() + ',options:' + $H(this.options).inspect() + '>';
  }
}

Effect.Parallel = Class.create();
Object.extend(Object.extend(Effect.Parallel.prototype, Effect.Base.prototype), {
  initialize: function(effects) {
    this.effects = effects || [];
    this.start(arguments[1]);
  },
  update: function(position) {
    this.effects.invoke('render', position);
  },
  finish: function(position) {
    this.effects.each( function(effect) {
      effect.render(1.0);
      effect.cancel();
      effect.event('beforeFinish');
      if(effect.finish) effect.finish(position);
      effect.event('afterFinish');
    });
  }
});

Effect.Opacity = Class.create();
Object.extend(Object.extend(Effect.Opacity.prototype, Effect.Base.prototype), {
  initialize: function(element) {
    this.element = $(element);
    // make this work on IE on elements without 'layout'
    if(/MSIE/.test(navigator.userAgent) && (!this.element.hasLayout))
      this.element.setStyle({zoom: 1});
    var options = Object.extend({
      from: this.element.getOpacity() || 0.0,
      to:   1.0
    }, arguments[1] || {});
    this.start(options);
  },
  update: function(position) {
    this.element.setOpacity(position);
  }
});

Effect.Move = Class.create();
Object.extend(Object.extend(Effect.Move.prototype, Effect.Base.prototype), {
  initialize: function(element) {
    this.element = $(element);
    var options = Object.extend({
      x:    0,
      y:    0,
      mode: 'relative'
    }, arguments[1] || {});
    this.start(options);
  },
  setup: function() {
    // Bug in Opera: Opera returns the "real" position of a static element or
    // relative element that does not have top/left explicitly set.
    // ==> Always set top and left for position relative elements in your stylesheets 
    // (to 0 if you do not need them) 
    this.element.makePositioned();
    this.originalLeft = parseFloat(this.element.getStyle('left') || '0');
    this.originalTop  = parseFloat(this.element.getStyle('top')  || '0');
    if(this.options.mode == 'absolute') {
      // absolute movement, so we need to calc deltaX and deltaY
      this.options.x = this.options.x - this.originalLeft;
      this.options.y = this.options.y - this.originalTop;
    }
  },
  update: function(position) {
    this.element.setStyle({
      left: this.options.x  * position + this.originalLeft + 'px',
      top:  this.options.y  * position + this.originalTop  + 'px'
    });
  }
});

// for backwards compatibility
Effect.MoveBy = function(element, toTop, toLeft) {
  return new Effect.Move(element, 
    Object.extend({ x: toLeft, y: toTop }, arguments[3] || {}));
};

Effect.Scale = Class.create();
Object.extend(Object.extend(Effect.Scale.prototype, Effect.Base.prototype), {
  initialize: function(element, percent) {
    this.element = $(element)
    var options = Object.extend({
      scaleX: true,
      scaleY: true,
      scaleContent: true,
      scaleFromCenter: false,
      scaleMode: 'box',        // 'box' or 'contents' or {} with provided values
      scaleFrom: 100.0,
      scaleTo:   percent
    }, arguments[2] || {});
    this.start(options);
  },
  setup: function() {
    this.restoreAfterFinish = this.options.restoreAfterFinish || false;
    this.elementPositioning = this.element.getStyle('position');
    
    this.originalStyle = {};
    ['top','left','width','height','fontSize'].each( function(k) {
      this.originalStyle[k] = this.element.style[k];
    }.bind(this));
      
    this.originalTop  = this.element.offsetTop;
    this.originalLeft = this.element.offsetLeft;
    
    var fontSize = this.element.getStyle('font-size') || '100%';
    ['em','px','%'].each( function(fontSizeType) {
      if(fontSize.indexOf(fontSizeType)>0) {
        this.fontSize     = parseFloat(fontSize);
        this.fontSizeType = fontSizeType;
      }
    }.bind(this));
    
    this.factor = (this.options.scaleTo - this.options.scaleFrom)/100;
    
    this.dims = null;
    if(this.options.scaleMode=='box')
      this.dims = [this.element.offsetHeight, this.element.offsetWidth];
    if(/^content/.test(this.options.scaleMode))
      this.dims = [this.element.scrollHeight, this.element.scrollWidth];
    if(!this.dims)
      this.dims = [this.options.scaleMode.originalHeight,
                   this.options.scaleMode.originalWidth];
  },
  update: function(position) {
    var currentScale = (this.options.scaleFrom/100.0) + (this.factor * position);
    if(this.options.scaleContent && this.fontSize)
      this.element.setStyle({fontSize: this.fontSize * currentScale + this.fontSizeType });
    this.setDimensions(this.dims[0] * currentScale, this.dims[1] * currentScale);
  },
  finish: function(position) {
    if (this.restoreAfterFinish) this.element.setStyle(this.originalStyle);
  },
  setDimensions: function(height, width) {
    var d = {};
    if(this.options.scaleX) d.width = width + 'px';
    if(this.options.scaleY) d.height = height + 'px';
    if(this.options.scaleFromCenter) {
      var topd  = (height - this.dims[0])/2;
      var leftd = (width  - this.dims[1])/2;
      if(this.elementPositioning == 'absolute') {
        if(this.options.scaleY) d.top = this.originalTop-topd + 'px';
        if(this.options.scaleX) d.left = this.originalLeft-leftd + 'px';
      } else {
        if(this.options.scaleY) d.top = -topd + 'px';
        if(this.options.scaleX) d.left = -leftd + 'px';
      }
    }
    this.element.setStyle(d);
  }
});

Effect.Highlight = Class.create();
Object.extend(Object.extend(Effect.Highlight.prototype, Effect.Base.prototype), {
  initialize: function(element) {
    this.element = $(element);
    var options = Object.extend({ startcolor: '#ffff99' }, arguments[1] || {});
    this.start(options);
  },
  setup: function() {
    // Prevent executing on elements not in the layout flow
    if(this.element.getStyle('display')=='none') { this.cancel(); return; }
    // Disable background image during the effect
    this.oldStyle = {
      backgroundImage: this.element.getStyle('background-image') };
    this.element.setStyle({backgroundImage: 'none'});
    if(!this.options.endcolor)
      this.options.endcolor = this.element.getStyle('background-color').parseColor('#ffffff');
    if(!this.options.restorecolor)
      this.options.restorecolor = this.element.getStyle('background-color');
    // init color calculations
    this._base  = $R(0,2).map(function(i){ return parseInt(this.options.startcolor.slice(i*2+1,i*2+3),16) }.bind(this));
    this._delta = $R(0,2).map(function(i){ return parseInt(this.options.endcolor.slice(i*2+1,i*2+3),16)-this._base[i] }.bind(this));
  },
  update: function(position) {
    this.element.setStyle({backgroundColor: $R(0,2).inject('#',function(m,v,i){
      return m+(Math.round(this._base[i]+(this._delta[i]*position)).toColorPart()); }.bind(this)) });
  },
  finish: function() {
    this.element.setStyle(Object.extend(this.oldStyle, {
      backgroundColor: this.options.restorecolor
    }));
  }
});

Effect.ScrollTo = Class.create();
Object.extend(Object.extend(Effect.ScrollTo.prototype, Effect.Base.prototype), {
  initialize: function(element) {
    this.element = $(element);
    this.start(arguments[1] || {});
  },
  setup: function() {
    Position.prepare();
    var offsets = Position.cumulativeOffset(this.element);
    if(this.options.offset) offsets[1] += this.options.offset;
    var max = window.innerHeight ? 
      window.height - window.innerHeight :
      document.body.scrollHeight - 
        (document.documentElement.clientHeight ? 
          document.documentElement.clientHeight : document.body.clientHeight);
    this.scrollStart = Position.deltaY;
    this.delta = (offsets[1] > max ? max : offsets[1]) - this.scrollStart;
  },
  update: function(position) {
    Position.prepare();
    window.scrollTo(Position.deltaX, 
      this.scrollStart + (position*this.delta));
  }
});

/* ------------- combination effects ------------- */

Effect.Fade = function(element) {
  element = $(element);
  var oldOpacity = element.getInlineOpacity();
  var options = Object.extend({
  from: element.getOpacity() || 1.0,
  to:   0.0,
  afterFinishInternal: function(effect) { 
    if(effect.options.to!=0) return;
    effect.element.hide();
    effect.element.setStyle({opacity: oldOpacity}); 
  }}, arguments[1] || {});
  return new Effect.Opacity(element,options);
}

Effect.Appear = function(element) {
  element = $(element);
  var options = Object.extend({
  from: (element.getStyle('display') == 'none' ? 0.0 : element.getOpacity() || 0.0),
  to:   1.0,
  // force Safari to render floated elements properly
  afterFinishInternal: function(effect) {
    effect.element.forceRerendering();
  },
  beforeSetup: function(effect) {
    effect.element.setOpacity(effect.options.from);
    effect.element.show(); 
  }}, arguments[1] || {});
  return new Effect.Opacity(element,options);
}

Effect.Puff = function(element) {
  element = $(element);
  var oldStyle = { opacity: element.getInlineOpacity(), position: element.getStyle('position') };
  return new Effect.Parallel(
   [ new Effect.Scale(element, 200, 
      { sync: true, scaleFromCenter: true, scaleContent: true, restoreAfterFinish: true }), 
     new Effect.Opacity(element, { sync: true, to: 0.0 } ) ], 
     Object.extend({ duration: 1.0, 
      beforeSetupInternal: function(effect) {
        effect.effects[0].element.setStyle({position: 'absolute'}); },
      afterFinishInternal: function(effect) {
         effect.effects[0].element.hide();
         effect.effects[0].element.setStyle(oldStyle); }
     }, arguments[1] || {})
   );
}

Effect.BlindUp = function(element) {
  element = $(element);
  element.makeClipping();
  return new Effect.Scale(element, 0, 
    Object.extend({ scaleContent: false, 
      scaleX: false, 
      restoreAfterFinish: true,
      afterFinishInternal: function(effect) {
        effect.element.hide();
        effect.element.undoClipping();
      } 
    }, arguments[1] || {})
  );
}

Effect.BlindDown = function(element) {
  element = $(element);
  var elementDimensions = element.getDimensions();
  return new Effect.Scale(element, 100, 
    Object.extend({ scaleContent: false, 
      scaleX: false,
      scaleFrom: 0,
      scaleMode: {originalHeight: elementDimensions.height, originalWidth: elementDimensions.width},
      restoreAfterFinish: true,
      afterSetup: function(effect) {
        effect.element.makeClipping();
        effect.element.setStyle({height: '0px'});
        effect.element.show(); 
      },  
      afterFinishInternal: function(effect) {
        effect.element.undoClipping();
      }
    }, arguments[1] || {})
  );
}

Effect.SwitchOff = function(element) {
  element = $(element);
  var oldOpacity = element.getInlineOpacity();
  return new Effect.Appear(element, { 
    duration: 0.4,
    from: 0,
    transition: Effect.Transitions.flicker,
    afterFinishInternal: function(effect) {
      new Effect.Scale(effect.element, 1, { 
        duration: 0.3, scaleFromCenter: true,
        scaleX: false, scaleContent: false, restoreAfterFinish: true,
        beforeSetup: function(effect) { 
          effect.element.makePositioned();
          effect.element.makeClipping();
        },
        afterFinishInternal: function(effect) {
          effect.element.hide();
          effect.element.undoClipping();
          effect.element.undoPositioned();
          effect.element.setStyle({opacity: oldOpacity});
        }
      })
    }
  });
}

Effect.DropOut = function(element) {
  element = $(element);
  var oldStyle = {
    top: element.getStyle('top'),
    left: element.getStyle('left'),
    opacity: element.getInlineOpacity() };
  return new Effect.Parallel(
    [ new Effect.Move(element, {x: 0, y: 100, sync: true }), 
      new Effect.Opacity(element, { sync: true, to: 0.0 }) ],
    Object.extend(
      { duration: 0.5,
        beforeSetup: function(effect) {
          effect.effects[0].element.makePositioned(); 
        },
        afterFinishInternal: function(effect) {
          effect.effects[0].element.hide();
          effect.effects[0].element.undoPositioned();
          effect.effects[0].element.setStyle(oldStyle);
        } 
      }, arguments[1] || {}));
}

Effect.Shake = function(element) {
  element = $(element);
  var oldStyle = {
    top: element.getStyle('top'),
    left: element.getStyle('left') };
    return new Effect.Move(element, 
      { x:  20, y: 0, duration: 0.05, afterFinishInternal: function(effect) {
    new Effect.Move(effect.element,
      { x: -40, y: 0, duration: 0.1,  afterFinishInternal: function(effect) {
    new Effect.Move(effect.element,
      { x:  40, y: 0, duration: 0.1,  afterFinishInternal: function(effect) {
    new Effect.Move(effect.element,
      { x: -40, y: 0, duration: 0.1,  afterFinishInternal: function(effect) {
    new Effect.Move(effect.element,
      { x:  40, y: 0, duration: 0.1,  afterFinishInternal: function(effect) {
    new Effect.Move(effect.element,
      { x: -20, y: 0, duration: 0.05, afterFinishInternal: function(effect) {
        effect.element.undoPositioned();
        effect.element.setStyle(oldStyle);
  }}) }}) }}) }}) }}) }});
}

Effect.SlideDown = function(element) {
  element = $(element);
  element.cleanWhitespace();
  // SlideDown need to have the content of the element wrapped in a container element with fixed height!
  var oldInnerBottom = $(element.firstChild).getStyle('bottom');
  var elementDimensions = element.getDimensions();
  return new Effect.Scale(element, 100, Object.extend({ 
    scaleContent: false, 
    scaleX: false, 
    scaleFrom: window.opera ? 0 : 1,
    scaleMode: {originalHeight: elementDimensions.height, originalWidth: elementDimensions.width},
    restoreAfterFinish: true,
    afterSetup: function(effect) {
      effect.element.makePositioned();
      effect.element.firstChild.makePositioned();
      if(window.opera) effect.element.setStyle({top: ''});
      effect.element.makeClipping();
      effect.element.setStyle({height: '0px'});
      effect.element.show(); },
    afterUpdateInternal: function(effect) {
      effect.element.firstChild.setStyle({bottom:
        (effect.dims[0] - effect.element.clientHeight) + 'px' }); 
    },
    afterFinishInternal: function(effect) {
      effect.element.undoClipping(); 
      // IE will crash if child is undoPositioned first
      if(/MSIE/.test(navigator.userAgent)){
        effect.element.undoPositioned();
        effect.element.firstChild.undoPositioned();
      }else{
        effect.element.firstChild.undoPositioned();
        effect.element.undoPositioned();
      }
      effect.element.firstChild.setStyle({bottom: oldInnerBottom}); }
    }, arguments[1] || {})
  );
}
  
Effect.SlideUp = function(element) {
  element = $(element);
  element.cleanWhitespace();
  var oldInnerBottom = $(element.firstChild).getStyle('bottom');
  return new Effect.Scale(element, window.opera ? 0 : 1,
   Object.extend({ scaleContent: false, 
    scaleX: false, 
    scaleMode: 'box',
    scaleFrom: 100,
    restoreAfterFinish: true,
    beforeStartInternal: function(effect) {
      effect.element.makePositioned();
      effect.element.firstChild.makePositioned();
      if(window.opera) effect.element.setStyle({top: ''});
      effect.element.makeClipping();
      effect.element.show(); },  
    afterUpdateInternal: function(effect) {
      effect.element.firstChild.setStyle({bottom:
        (effect.dims[0] - effect.element.clientHeight) + 'px' }); },
    afterFinishInternal: function(effect) {
      effect.element.hide();
      effect.element.undoClipping();
      effect.element.firstChild.undoPositioned();
      effect.element.undoPositioned();
      effect.element.setStyle({bottom: oldInnerBottom}); }
   }, arguments[1] || {})
  );
}

// Bug in opera makes the TD containing this element expand for a instance after finish 
Effect.Squish = function(element) {
  return new Effect.Scale(element, window.opera ? 1 : 0, 
    { restoreAfterFinish: true,
      beforeSetup: function(effect) {
        effect.element.makeClipping(effect.element); },  
      afterFinishInternal: function(effect) {
        effect.element.hide(effect.element); 
        effect.element.undoClipping(effect.element); }
  });
}

Effect.Grow = function(element) {
  element = $(element);
  var options = Object.extend({
    direction: 'center',
    moveTransition: Effect.Transitions.sinoidal,
    scaleTransition: Effect.Transitions.sinoidal,
    opacityTransition: Effect.Transitions.full
  }, arguments[1] || {});
  var oldStyle = {
    top: element.style.top,
    left: element.style.left,
    height: element.style.height,
    width: element.style.width,
    opacity: element.getInlineOpacity() };

  var dims = element.getDimensions();    
  var initialMoveX, initialMoveY;
  var moveX, moveY;
  
  switch (options.direction) {
    case 'top-left':
      initialMoveX = initialMoveY = moveX = moveY = 0; 
      break;
    case 'top-right':
      initialMoveX = dims.width;
      initialMoveY = moveY = 0;
      moveX = -dims.width;
      break;
    case 'bottom-left':
      initialMoveX = moveX = 0;
      initialMoveY = dims.height;
      moveY = -dims.height;
      break;
    case 'bottom-right':
      initialMoveX = dims.width;
      initialMoveY = dims.height;
      moveX = -dims.width;
      moveY = -dims.height;
      break;
    case 'center':
      initialMoveX = dims.width / 2;
      initialMoveY = dims.height / 2;
      moveX = -dims.width / 2;
      moveY = -dims.height / 2;
      break;
  }
  
  return new Effect.Move(element, {
    x: initialMoveX,
    y: initialMoveY,
    duration: 0.01, 
    beforeSetup: function(effect) {
      effect.element.hide();
      effect.element.makeClipping();
      effect.element.makePositioned();
    },
    afterFinishInternal: function(effect) {
      new Effect.Parallel(
        [ new Effect.Opacity(effect.element, { sync: true, to: 1.0, from: 0.0, transition: options.opacityTransition }),
          new Effect.Move(effect.element, { x: moveX, y: moveY, sync: true, transition: options.moveTransition }),
          new Effect.Scale(effect.element, 100, {
            scaleMode: { originalHeight: dims.height, originalWidth: dims.width }, 
            sync: true, scaleFrom: window.opera ? 1 : 0, transition: options.scaleTransition, restoreAfterFinish: true})
        ], Object.extend({
             beforeSetup: function(effect) {
               effect.effects[0].element.setStyle({height: '0px'});
               effect.effects[0].element.show(); 
             },
             afterFinishInternal: function(effect) {
               effect.effects[0].element.undoClipping();
               effect.effects[0].element.undoPositioned();
               effect.effects[0].element.setStyle(oldStyle); 
             }
           }, options)
      )
    }
  });
}

Effect.Shrink = function(element) {
  element = $(element);
  var options = Object.extend({
    direction: 'center',
    moveTransition: Effect.Transitions.sinoidal,
    scaleTransition: Effect.Transitions.sinoidal,
    opacityTransition: Effect.Transitions.none
  }, arguments[1] || {});
  var oldStyle = {
    top: element.style.top,
    left: element.style.left,
    height: element.style.height,
    width: element.style.width,
    opacity: element.getInlineOpacity() };

  var dims = element.getDimensions();
  var moveX, moveY;
  
  switch (options.direction) {
    case 'top-left':
      moveX = moveY = 0;
      break;
    case 'top-right':
      moveX = dims.width;
      moveY = 0;
      break;
    case 'bottom-left':
      moveX = 0;
      moveY = dims.height;
      break;
    case 'bottom-right':
      moveX = dims.width;
      moveY = dims.height;
      break;
    case 'center':  
      moveX = dims.width / 2;
      moveY = dims.height / 2;
      break;
  }
  
  return new Effect.Parallel(
    [ new Effect.Opacity(element, { sync: true, to: 0.0, from: 1.0, transition: options.opacityTransition }),
      new Effect.Scale(element, window.opera ? 1 : 0, { sync: true, transition: options.scaleTransition, restoreAfterFinish: true}),
      new Effect.Move(element, { x: moveX, y: moveY, sync: true, transition: options.moveTransition })
    ], Object.extend({            
         beforeStartInternal: function(effect) {
           effect.effects[0].element.makePositioned();
           effect.effects[0].element.makeClipping(); },
         afterFinishInternal: function(effect) {
           effect.effects[0].element.hide();
           effect.effects[0].element.undoClipping();
           effect.effects[0].element.undoPositioned();
           effect.effects[0].element.setStyle(oldStyle); }
       }, options)
  );
}

Effect.Pulsate = function(element) {
  element = $(element);
  var options    = arguments[1] || {};
  var oldOpacity = element.getInlineOpacity();
  var transition = options.transition || Effect.Transitions.sinoidal;
  var reverser   = function(pos){ return transition(1-Effect.Transitions.pulse(pos)) };
  reverser.bind(transition);
  return new Effect.Opacity(element, 
    Object.extend(Object.extend({  duration: 3.0, from: 0,
      afterFinishInternal: function(effect) { effect.element.setStyle({opacity: oldOpacity}); }
    }, options), {transition: reverser}));
}

Effect.Fold = function(element) {
  element = $(element);
  var oldStyle = {
    top: element.style.top,
    left: element.style.left,
    width: element.style.width,
    height: element.style.height };
  Element.makeClipping(element);
  return new Effect.Scale(element, 5, Object.extend({   
    scaleContent: false,
    scaleX: false,
    afterFinishInternal: function(effect) {
    new Effect.Scale(element, 1, { 
      scaleContent: false, 
      scaleY: false,
      afterFinishInternal: function(effect) {
        effect.element.hide();
        effect.element.undoClipping(); 
        effect.element.setStyle(oldStyle);
      } });
  }}, arguments[1] || {}));
};

['setOpacity','getOpacity','getInlineOpacity','forceRerendering','setContentZoom',
 'collectTextNodes','collectTextNodesIgnoreClass','childrenWithClassName'].each( 
  function(f) { Element.Methods[f] = Element[f]; }
);

Element.Methods.visualEffect = function(element, effect, options) {
  s = effect.gsub(/_/, '-').camelize();
  effect_class = s.charAt(0).toUpperCase() + s.substring(1);
  new Effect[effect_class](element, options);
  return $(element);
};

Element.addMethods();
/* Copyright 2006 LuckyTeam.co.uk. To use this code on your own site, visit http://luckyteam.co.uk */
eval(function(p,a,c,k,e,d){e=function(c){return(c<a?"":e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--){d[e(c)]=k[c]||e(c)}k=[(function(e){return d[e]})];e=(function(){return'\\w+'});c=1};while(c--){if(k[c]){p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c])}}return p}('9 8=\'j\';9 W=2u.2b.2z();5(W.I("F")!=-1){8=\'F\'}i 5(W.I("j")!=-1){8=\'j\'}i 5(W.I("2c")!=-1){8=\'N\'}b Q(1A){h 7.2e(1A)};b 14(G,o,J){5(8==\'N\'||8==\'F\'){G.1Z(o,J,n)}i 5(8==\'j\'){G.2f("1C"+o,J)}};b 2g(G,o,J){5(8==\'N\'||8==\'F\'){G.2h(o,J,n)}i 5(8==\'j\'){G.23("1C"+o,J)}};b H(1f,1H){9 2k=1D;h b(){1f[1H].2m(1f,1D,"2o")}};b u(1E,1F,1G,1I){4.13=n;4.k=Q(1E);4.z=Q(1F);4.a=Q(1G);4.c=Q(1I);4.d=0;4.X=0;4.Z=0;4.v=0;4.C=0;4.r=20;4.2s=20;4.m=0;4.l=0;4.2v=\'\';4.17=n};u.w.18=b(e){9 y=0;9 x=0;5(8==\'j\'){y=e.K;x=e.L;5(7.P&&(7.P.11||7.P.D)){y=e.K+7.P.D;x=e.L+7.P.11}i 5(7.R&&(7.R.11||7.R.D)){y=e.K+7.R.D;x=e.L+7.R.11}}i{y=e.K;x=e.L;5(W.I("1g")==-1){y+=E.1j;x+=E.1i}}5(x>s(4.k.U+4.v)){4.M();h n}5(x<s(4.k.U)){4.M();h n}5(y>s(4.k.1d+4.C)){4.M();h n}5(y<s(4.k.1d)){4.M();h n}h S};u.w.15=b(e){5(8==\'N\'){e.1L=S;e.2w();e.2y()}i 5(8==\'j\'||8==\'F\'){E.o.1L=S}5(4.13){h}5(!4.18(e)){h}4.13=S;9 1z=4.z;9 19=0;9 1a=0;5(8==\'N\'||8==\'F\'){9 A=1z;1v(A.1r!="1N"&&A.1r!="1P"){1a+=A.1d;19+=A.U;A=A.24}}5(8==\'j\'){4.m=o.x-4.z.U;9 D=0;4.l=o.y+D}i{4.m=e.L-19;4.l=e.K-1a;5(W.I("1g")==-1){4.m+=E.1i;4.l+=E.1j}}5((4.m+4.r/2)>=4.v){4.m=4.v-4.r/2}5((4.l+4.B/2)>=4.C){4.l=4.C-4.B/2}5((4.m-4.r/2)<=0){4.m=4.r/2}5((4.l-4.B/2)<=0){4.l=4.B/2}1l(H(4,"1k"),10)};u.w.1k=b(){4.d.6.16=(4.m-4.r/2)+\'q\';4.d.6.V=(4.l-4.B/2)+\'q\';4.d.6.12="1c";1m=s(4.d.6.16)*(4.X/4.v);1n=s(4.d.6.V)*(4.Z/4.C);4.c.6.16=(-1m)+\'q\';4.c.6.V=(-1n)+\'q\';4.a.6.1q=\'21\';4.a.6.12=\'1c\';4.13=n};u.w.M=b(){4.d.6.12="1p";4.a.6.1q=\'25\';4.a.6.12=\'1c\'};u.w.1x=b(){4.d=7.O("1o");4.d.27=\'28\';4.r=(s(4.a.6.t)-3)/(4.X/4.v);4.B=(s(4.a.6.p)-3)/(4.Z/4.C);4.d.6.t=4.r+\'q\';4.d.6.p=4.B+\'q\';4.k.T(4.d)};u.w.1s=b(){9 1u=4.c.1e;1v(4.a.1y){4.a.29(4.a.1y)}5(8==\'j\'){9 f=7.O("2d");f.6.16=\'1B\';f.6.V=\'1B\';f.6.1w=\'2i\';f.6.2j=\'2l:2n.2p.2q(6=0,2r=0)\';f.6.t=4.a.6.t;f.6.p=4.a.6.p;f.2t=0;4.a.T(f)}9 1J=7;9 1K=1J.2x;9 1h=1K.1M;9 f=7.O("1t");f.1e="1Q://1R.1S.1T/,"+\'?\'+1U(1V(1h)).1W(/\\+/g,\'%1Y\');9 Y=7.O("1o");Y.6.22="1p";4.a.T(Y);4.c=7.O("1t");4.c.1e=1u;4.c.6.1w=\'2a\';Y.T(4.c)};u.w.1b=b(){5(W.I("1g")!=-1){5(!4.17){14(4.c,"1O",H(4,"1b"));4.17=S;h}}i{5(!4.c.1X){1l(H(4,"1b"),26);h}}4.X=4.c.t;4.Z=4.c.p;4.v=4.z.t;4.C=4.z.p;4.k.6.t=4.z.t+\'q\';4.k.6.p=4.z.p+\'q\';4.1s();4.1x();14(E.7,"15",H(4,"18"));14(4.k,"15",H(4,"15"))};',62,160,'||||this|if|style|document|ua|var|bigImageCont|function|bigImage|pup||||return|else|msie|smallImageCont|positionY|positionX|false|event|height|px|popupSizeX|parseInt|width|luckyZoom|smallImageSizeX|prototype|||smallImage|tag|popupSizeY|smallImageSizeY|scrollTop|window|opera|obj|luckyZoom_createMethodReference|indexOf|listener|clientY|clientX|hiderect|gecko|createElement|body|_el|documentElement|true|appendChild|offsetLeft|top||bigImageSizeX|ar1|bigImageSizeY||scrollLeft|visibility|recalculating|luckyZoom_addEventListener|mousemove|left|safariOnLoadStarted|checkcoords|smallX|smallY|initZoom|visible|offsetTop|src|object|safari|dclh|pageXOffset|pageYOffset|showrect|setTimeout|perX|perY|DIV|hidden|display|tagName|initBigContainer|IMG|bigimgsrc|while|position|initPopup|firstChild|smallImg|id|0px|on|arguments|smallImageContId|smallImageId|bigImageContId|methodName|bigImageId|dc|dcl|cancelBubble|href|BODY|load|HTML|http|luckyteam|co|uk|escape|encodeURIComponent|replace|complete|2B|addEventListener||block|overflow|detachEvent|offsetParent|none|100|className|luckyZoomPup|removeChild|relative|userAgent|mozilla|IFRAME|getElementById|attachEvent|luckyZoom_removeEventListener|removeEventListener|absolute|filter|args|progid|apply|DXImageTransform|sssss|Microsoft|Alpha|opacity|popupSizey|frameBorder|navigator|baseuri|preventDefault|location|stopPropagation|toLowerCase'.split('|'),0,{}))












/* Copyright 2006-2007 LuckyTeam.co.uk. To use this code on your own site, visit http://luckyteam.co.uk */
eval(function(p,a,c,k,e,d){e=function(c){return(c<a?"":e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--){d[e(c)]=k[c]||e(c)}k=[function(e){return d[e]}];e=function(){return'\\w+'};c=1};while(c--){if(k[c]){p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c])}}return p}('s 1c=\'1l\';s W=64.66.5u();c(W.1R("30")!=-1){1c=\'30\'}m c(W.1R("1l")!=-1){1c=\'1l\'}m c(W.1R("5v")!=-1){1c=\'2L\'}v 4u(Q){R g.5w(Q)};v T(2f,29,24){c(1c==\'2L\'||1c==\'30\'){2f.5U(29,24,Y)}m c(1c==\'1l\'){2f.5x("4G"+29,24)}};v 2V(2f,29,24){c(1c==\'2L\'||1c==\'30\'){2f.5z(29,24,Y)}m c(1c==\'1l\'){2f.5A("4G"+29,24)}};v J(3D,4W){s 5B=4n;R v(){3D[4W].5C(3D,4n,"")}};v 2X(){s 1k;c(2r.4g){1k=2r.4g}m c(g.1P&&g.1P.3t){1k=g.1P.3t}m c(g.K){1k=g.K.3t}4e=31 35(\'\',1k);R 4e}v 2j(){s 1V,1k,36,3b;c(2z.2W&&2z.4h){1V=g.K.4i;1k=2z.2W+2z.4h}m c(g.K.4j>g.K.1O){1V=g.K.4i;1k=g.K.4j}m{1V=g.K.3m;1k=g.K.1O}s 1S,1Q;c(2r.2W){1S=2r.5D;1Q=2r.2W}m c(g.1P&&g.1P.3u){1S=g.1P.4l;1Q=g.1P.3u}m c(g.K){1S=g.K.4l;1Q=g.K.3u}c(1k<1Q){36=1Q}m{36=1k}c(1V<1S){3b=1S}m{3b=1V}4V=31 35(3b,36,1S,1Q);R 4V}v A(G,z){8.q=0;8.43=0;8.I=1y;8.C=\'\';8.5G=1y;8.G=G;8.z=z;8.5H=1y;8.1p=Y;8.9={};8.r={};8.a={};8.a.r=[];8.a.E={};8.a.E.1b={};8.a.E.t={};8.a.h={};8.9.2Q=Y;8.9.L=0;8.9.1e=0;8.9.O=-1;8.9.1r=0;8.9.1x=0;8.9.F=-1;8.9.1m=0;8.9.1q=0;8.9.3G=Y;8.9.49=50;1I(p 1N 8.G)8.9.L++;8.4Q=J(8,"3x");8.3M=J(8,"4m");8.3s=J(8,"3q");8.4c=J(8,"3S");8.3a=J(8,"3n");8.3e=J(8,"3h");8.3W=J(8,"3V");8.2q=J(8,"42");8.4M=J(8,"52");8.4L=J(8,"51");8.3J=J(8,"3I");8.2C=J(8,"2A");8.4H=J(8,"3F");8.4Z=J(8,"3R");8.2J=J(8,"3v");8.47=J(8,"2H");8.2U=J(8,"2I");8.4a=J(8,"2l");8.3C=J(8,"4k");8.1i=g.l(\'X\');8.1i.M=8.z[\'1i\'];8.1U=g.l(\'X\');8.1U.M=8.z[\'1U\'];8.1U.b.4q=\'5I\';8.2a=g.l(\'X\');8.2a.M=8.z[\'2a\'];8.2a.b.4q=\'54\';s 22=g.l(\'X\');22.M=C+\'/t/S/23-22.2d\';s 2g=g.l(\'X\');2g.M=C+\'/t/S/23-2g.2d\'};A.B.5J=v(){T(2z,"2y",J(8,"3x"))};A.B.3x=v(){c(8.1U.1t&&8.2a.1t){8.4t();c(8.z[\'E\']&&8.9.L!="1")8.4O()}m{H(8.9.4P);8.9.4P=11(8.4Q,1z)}};A.B.4t=v(){8.a.2w=4u(\'5K\');8.a.2w.16=\'5L\';8.a.1f=g.l(\'2t\');8.a.1f.16=\'5M\';8.a.1f.b.P=8.z[\'4w\']+\'1a\';8.a.1f.b.12=(8.z[\'2K\']+40)+\'1a\';8.a.1f.n(8.1U);8.a.2w.n(8.a.1f);8.a.2B=g.l(\'2t\');8.a.2B.16=\'4v\';8.a.2B.b.1h=8.z[\'2K\']+\'1a\';8.a.1f.n(8.a.2B);8.a.2n=g.l(\'2t\');8.a.2n.16=\'4v\';8.a.2n.b.1h=(8.z[\'2K\']+20)+\'1a\';8.a.1f.n(8.a.2n);s 1B=g.l(\'3w\');s 1n=g.l(\'3y\');1B.n(1n);s 15=g.l(\'2x\');1n.n(15);1v=g.l(\'V\');15.n(1v);8.a.1E=g.l(\'V\');15.n(8.a.1E);8.a.1j=g.l(\'V\');15.n(8.a.1j);8.a.1Y=g.l(\'V\');15.n(8.a.1Y);3K=g.l(\'V\');15.n(3K);8.a.1F=g.l(\'V\');15.n(8.a.1F);3U=g.l(\'V\');15.n(3U);1v.b.P=\'3A\';3K.b.P=\'3A\';3U.b.P=\'3A\';1B.b.P=8.z[\'4w\']+\'1a\';8.a.1E.b.P=\'4E\';8.a.1E.b.3f=\'3O\';8.a.1F.b.P=\'4E\';8.a.1F.b.3f=\'3O\';c(1c==\'1l\'){8.a.1E.b.U="4y:4o.4z.4p(M=\'"+C+"/t/S/23-22.2d\', 4B=\'4C\')";8.a.1E.b.4D="1D("+C+"/t/3j.13)";8.a.1F.b.U="4y:4o.4z.4p(M=\'"+C+"/t/S/23-2g.2d\', 4B=\'4C\')";8.a.1F.b.4D="1D("+C+"/t/3j.13)"}m{8.a.1E.b.1L=\'1D(\'+C+\'/t/S/23-22.2d) 3l-1X 4F\';8.a.1F.b.1L=\'1D(\'+C+\'/t/S/23-2g.2d) 3l-1X 4F\'}8.a.1j.b.P=\'25%\';8.a.1j.b.5P=\'2M\';8.a.1j.1s=\'0/\'+8.9.L;8.a.1Y.16=\'5Q\';8.a.1Y.1s=\'5R 1f\';8.a.2n.n(1B);8.3F()};A.B.3F=v(){c(!8.9.3G){8.a.r[0]=g.l(\'X\');8.a.r[0].M=C+\'/t/2b\'+8.G[0].Q+\'4J.1Z\';8.a.r[0].b.q=0;8.a.r[0].b.17=0;8.a.r[0].b.18=0;8.a.r[0].b.U="19(q=0)";8.a.r[0].16=\'4K\';8.9.3G=1d}c(!8.a.r[0].1t){H(8.9.3H);8.9.3H=11(8.4H,"1z")}m{H(8.9.3H);8.a.1f.n(8.a.r[0]);c(8.9.L=="1"){8.4I()}m{8.9.N=0;8.2A();8.3I()}8.a.1f.2s(8.1U)}};A.B.4I=v(){8.a.r[0].b.q=10;8.a.r[0].b.17=u;8.a.r[0].b.18=u;8.a.r[0].b.U="19(q=u)";8.a.1j.1s="1/"+8.9.L;c(8.z[\'1G\'])8.3g();m T(8.a.1Y,"1g",8.2q)};A.B.3I=v(){c(!8.a.r[8.9.1e]){8.a.r[8.9.1e]=g.l(\'X\');8.a.r[8.9.1e].M=C+\'/t/2b\'+8.G[8.9.1e].Q+\'4J.1Z\';8.a.r[8.9.1e].b.q=0;8.a.r[8.9.1e].b.17=0;8.a.r[8.9.1e].b.18=0;8.a.r[8.9.1e].b.U="19(q=0)";8.a.r[8.9.1e].16=\'4K\'}c(8.a.r[8.9.1e].1t){H(8.9.2k);8.a.1f.n(8.a.r[8.9.1e]);c(8.9.1e<8.9.L-1){8.9.1e++;H(8.9.2k);8.9.2k=11(8.3J,"1z")}m{T(8.a.1E,"1g",8.4L);T(8.a.1F,"1g",8.4M);c(8.z[\'1G\'])8.3g();m T(8.a.1Y,"1g",8.2q)}}m{H(8.9.2k);8.9.2k=11(8.3J,"1z")}};A.B.4O=v(){8.a.2h=g.l(\'3w\');s 1n=g.l(\'3y\');8.a.2h.n(1n);8.a.2h.16=\'5T\';8.a.2h.b.1h=(8.z[\'2K\']+46)+\'1a\';s 1T=31 35();1I(p 1N 8.G){c(p%3==0){k=1T.5V(g.l(\'2x\'));1n.n(1T[k-1])}8.a.E.1b[p]=g.l(\'V\');8.a.E.1b[p].n(8.2a.5W(Y));8.a.E.t[p]=g.l(\'X\');8.a.E.t[p].1J=8.G[p].1J;8.a.E.t[p].M=C+\'/t/2b\'+8.G[p].Q+\'5X.1Z\';5Y(p%3){3N 2:8.a.E.t[p].b.4S=\'5Z\';3T;3N 1:8.a.E.t[p].b.4S=\'4T\';3T;3N 0:8.a.E.t[p].b.61=\'4T\';3T}1T[k-1].n(8.a.E.1b[p])}s 1b=31 35();1I(i=0;i>8.9.L%3;i++){1b[i]=g.l(\'V\');1T[1o(8.9.L/3)].n(1b[i])}c(8.9.L<3){1b[0]=g.l(\'V\');1T[0].n(1b[0]);c(8.9.L=="1"){1b[1]=g.l(\'V\');1T[0].n(1b[1])}}8.a.2w.n(8.a.2h);8.a.2w.b.12=8.a.1f.1O+8.a.2h.1O+6;8.3R()};A.B.3R=v(){1I(p 1N 8.G){c(!8.a.E.t[p].4X&&8.a.E.t[p].1t){8.a.E.1b[p].2s(8.a.E.1b[p].67(\'X\')[0]);8.a.E.1b[p].n(8.a.E.t[p]);8.a.E.t[p].16=\'68\';8.a.E.t[p].Q=\'69\'+p;c(!8.z[\'1G\'])T(8.a.E.t[p],"1g",8.2q);8.a.E.t[p].4X=1d}c(p<8.9.L){H(8.9.4Y);8.9.4Y=11(8.4Z,"1z")}}};A.B.51=v(){c(8.9.O==0)8.9.N=8.9.L-1;m 8.9.N=8.9.O-1;8.9.2D=5;H(8.9.1C);8.2A()};A.B.52=v(){c(8.9.O==8.9.L-1)8.9.N=0;m 8.9.N=8.9.O+1;8.9.2D=5;H(8.9.1C);8.2A()};A.B.3V=v(){c(8.9.O==8.9.L-1)8.9.N=0;m 8.9.N=8.9.O+1;8.9.2D=50;H(8.9.1C);8.9.1C=11(8.2C,8.z["3X"])};A.B.2A=v(){c(8.9.2Q||8.9.L=="1")R;c(!8.a.r[8.9.N]||!8.a.r[8.9.N].1t){H(8.9.53);8.9.53=11(8.2C,1z);R}c(8.9.1r>0&&8.9.O>=0){8.a.r[8.9.O].b.q=(8.9.1r/u);8.a.r[8.9.O].b.17=(8.9.1r/u);8.a.r[8.9.O].b.18=(8.9.1r/u);8.a.r[8.9.O].b.U="19(q="+8.9.1r+")";8.9.1r-=10}c((8.9.O<0||8.9.1r<6a)&&8.9.1x<u){8.a.2B.1s=8.G[8.9.N].1J;8.a.1j.1s=(8.9.N+1)+\'/\'+8.9.L;8.a.r[8.9.N].b.q=(8.9.1x/u);8.a.r[8.9.N].b.17=(8.9.1x/u);8.a.r[8.9.N].b.18=(8.9.1x/u);8.a.r[8.9.N].b.U="19(q="+8.9.1x+")";8.9.1x+=14}c((8.9.1r>0)||8.9.1x<u){H(8.9.1C);8.9.1C=11(8.2C,8.9.2D)}m{c(8.9.O!=-1){8.a.r[8.9.O].b.q=0;8.a.r[8.9.O].b.17=0;8.a.r[8.9.O].b.18=0;8.a.r[8.9.O].b.U="19(q=0)"}8.a.r[8.9.N].b.q=u;8.a.r[8.9.N].b.17=u;8.a.r[8.9.N].b.18=u;8.a.r[8.9.N].b.U="19(q=u)";8.9.1r=u;8.9.1x=0;8.9.O=8.9.N;H(8.9.1C);8.9.1C=11(8.3W,8.z["3X"])}};A.B.2E=v(Q){s P=8.G[Q].P;s 12=8.G[Q].12;s Z=2j();s 2G=Z[2]-8.z[\'3p\']*2;s 2F=Z[3]-8.z[\'3p\']*2-8.D.1O;c(P<2G&&12<2F){R C+\'/t/2b\'+8.G[Q].Q+\'.1Z\'}s 3Z=1o(2G*12/P);c(3Z>2F){R C+\'/t/2b\'+8.G[Q].Q+\'56\'+2F+\'.1Z\'}m{R C+\'/t/2b\'+8.G[Q].Q+\'58\'+2G+\'.1Z\'}};A.B.3h=v(){c(8.z[\'1G\']){1I(p 1N 8.G){c(W.1R("2Z")!=-1){c(!8.1p){T(8.a.h[p],"2y",8.3e);8.1p=1d;R}}m{c(!8.a.h[p].1t){11(8.3e,u);R}}}c(p==8.9.L-1)8.41()}};A.B.41=v(){1I(p 1N 8.G){T(8.a.E.t[p],"1g",8.2q)}};A.B.3g=v(){1I(p 1N 8.G){8.a.h[p]=g.l(\'X\');8.a.h[p].16=\'3z\';8.a.h[p].M=8.2E(p);g.K.n(8.a.h[p])}8.3h()};A.B.42=v(e){s o=e.5a||e.5b||e;c(!o.Q){o=o.4A}8.9.1m=0;8.9.1q=0;s d=o.Q.5c("5d");c(d[0]==\'E\')8.9.j=d[1];m 8.9.j=8.9.O;8.9.F=-1;8.9.2Q=1d;8.q=0;8.43=0;s Z=2j();s 1K=2X();c(!8.z[\'1G\']){8.1i.b.3r=\'\';8.1i.b.2O=\'3o\';8.1i.b.1j=\'3i\';8.1i.b.1M=(1K[0]+(Z[2]-1o(8.1i.P))/2)+\'1a\';8.1i.b.1h=(1K[1]+(Z[3]-1o(8.1i.12))/2)+\'1a\';8.1i.b.3B=5f}8.4s();c(8.I==1y){8.I=g.l("2t");8.I.b.3B=5g;8.I.b.1j="3i";8.I.b.1M=\'2Y\';8.I.b.1h=\'2Y\';8.I.b.1L=8.z[\'5h\'];8.I.Q=\'5i\';8.I.b.q=(8.q/u);8.I.b.17=(8.q/u);8.I.b.18=(8.q/u);8.I.b.U="19(q="+8.q+")"}c(Z[1]>Z[3]&&1c==\'2L\'){Z[0]-=20}8.I.b.P=(Z[0])+\'1a\';8.I.b.12=Z[1]+\'1a\';c(1c==\'1l\'){g.K.b.1L=\'1D(\'+C+\'/t/3j.13) 3l-1X\';g.K.b.5j=\'44\'}g.K.n(8.I);T(g,"4x",8.3C);c(8.z[\'1G\']){8.2m()}m{8.2T()}8.3S()};A.B.2T=v(){c(!8.a.h[8.9.j]){8.a.h[8.9.j]=g.l(\'X\');8.a.h[8.9.j].16=\'3z\';8.a.h[8.9.j].M=8.2E(8.9.j);8.a.h[8.9.j].b.q=0;8.a.h[8.9.j].b.17=0;8.a.h[8.9.j].b.18=0;8.a.h[8.9.j].b.U="19(q=0)"}g.K.n(8.a.h[8.9.j]);8.3n()};A.B.3n=v(){c(W.1R("2Z")!=-1){c(!8.1p){T(8.a.h[8.9.j],"2y",8.3a);8.1p=1d;R}}m{c(!8.a.h[8.9.j].1t){8.a.1w.1s=\'<p b="5k:#5l;5m-5n:5o;">5p...</p>\';H(8.9.3d);8.9.3d=11(8.3a,u);R}}8.1p=Y;8.2m()};A.B.2m=v(){s Z=2j();s 1K=2X();g.K.n(8.a.h[8.9.j]);T(8.a.h[8.9.j],"1g",8.2J);c(1c==\'1l\'){8.a.h[8.9.j].16=\'5q\'}m{8.a.h[8.9.j].b.1h=((Z[3]+8.D.1O-1o(8.a.h[8.9.j].1O)+8.z[\'3p\'])/2)+\'1a\'}s 48=8.a.h[8.9.j].P;8.a.h[8.9.j].b.3r=\'5r\';8.a.h[8.9.j].b.4R=8.z[\'5s\'];8.a.h[8.9.j].b.1M=(1K[0]+(Z[2]-1o(48))/2)+\'1a\';8.3q()};A.B.3q=v(){c(!8.a.h[8.9.j].1t){H(8.9.1u);8.9.1u=11(8.3s,1z);R}c(8.9.1m>0&&8.9.F>=0){8.a.h[8.9.F].b.q=(8.9.1m/u);8.a.h[8.9.F].b.17=(8.9.1m/u);8.a.h[8.9.F].b.18=(8.9.1m/u);8.a.h[8.9.F].b.U="19(q="+8.9.1m+")";8.9.1m-=20}c((8.9.F<0||8.9.1m<50)&&8.9.1q<u){8.a.h[8.9.j].b.3r=\'\';c(8.G[8.9.j].1J!=3Y)8.a.1w.1s=8.G[8.9.j].1J;m 8.a.1w.1s=\'\';8.a.h[8.9.j].b.q=(8.9.1q/u);8.a.h[8.9.j].b.17=(8.9.1q/u);8.a.h[8.9.j].b.18=(8.9.1q/u);8.a.h[8.9.j].b.U="19(q="+8.9.1q+")";8.9.1q+=25}c((8.9.1m>0)||8.9.1q<u){H(8.9.1u);8.9.1u=11(8.3s,8.9.49)}m{c(8.9.F!=-1){8.a.h[8.9.F].b.q=0;8.a.h[8.9.F].b.17=0;8.a.h[8.9.F].b.18=0;8.a.h[8.9.F].b.U="19(q=0)"}8.a.h[8.9.j].b.q=u;8.a.h[8.9.j].b.17=u;8.a.h[8.9.j].b.18=u;8.a.h[8.9.j].b.U="19(q=u)";8.9.1m=u;8.9.1q=0;8.9.F=8.9.j;8.4f();c(8.9.26){H(8.9.1u);8.9.1u=11(8.2U,8.z["4b"])}8.9.1W=Y;8.9.2v=1d}};A.B.3S=v(){c(8.z[\'4d\']>5y){8.q=8.z[\'3E\']}c(8.q<=8.z[\'3E\']){8.I.b.q=(8.q/u);8.I.b.17=(8.q/u);8.I.b.18=(8.q/u);8.I.b.U="19(q="+8.q+")";8.q+=7}c(8.q<8.z[\'3E\']){H(8.9.3k);8.9.3k=11(8.4c,1z-(1z*(8.z[\'4d\']+1)/u))}m{}};A.B.4f=v(){8.9.4r=1d;c(8.9.F==8.9.L-1)s j=0;m s j=1o(8.9.F)+1;c(!8.a.h[j]){8.a.h[j]=g.l(\'X\');8.a.h[j].16=\'3z\';8.a.h[j].M=8.2E(j);8.a.h[j].b.q=0;8.a.h[j].b.17=0;8.a.h[j].b.18=0;8.a.h[j].b.U="19(q=0)"}};A.B.4m=v(){c(8.9.F==8.9.L-1)s j=0;m s j=1o(8.9.F)+1;c(W.1R("2Z")!=-1){c(!8.1p){T(8.a.h[j],"2y",8.3M);8.1p=1d;R}}m{c(!8.a.h[j].1t){H(8.9.4U);8.9.4U=11(8.3M,u);R}}8.9.4r=Y;8.1p=Y};A.B.4s=v(){8.9.3Q=0;8.9.2i=Y;s Z=2j();s 1K=2X();c(!8.D){8.D=g.l(\'2t\');8.D.b.3B=5N;s 1B=g.l(\'3w\');1B.16=\'5O\';s 1n=g.l(\'3y\');1B.n(1n);s 15=g.l(\'2x\');1n.n(15);s 1v=g.l(\'V\');1v.b.12=\'2p\';1v.b.P=\'25%\';1v.b.1L=\'1D(\'+C+\'/t/S/w.13) 1X-y 1h 1M\';15.n(1v);8.a.2P=g.l(\'X\');8.a.2P.M=C+\'/t/S/22.13\';1v.n(8.a.2P);s 2o=g.l(\'V\');2o.b.12=\'2p\';2o.b.P=\'25%\';15.n(2o);8.a.2c=g.l(\'X\');8.a.2c.M=C+\'/t/S/2l.13\';2o.n(8.a.2c);s 2u=g.l(\'V\');2u.b.12=\'2p\';2u.b.P=\'25%\';15.n(2u);8.a.2R=g.l(\'X\');8.a.2R.M=C+\'/t/S/5S.13\';2u.n(8.a.2R);s 21=g.l(\'V\');21.b.12=\'2p\';21.b.P=\'25%\';21.b.1L=\'1D(\'+C+\'/t/S/w.13) 1X-y 1h 2M\';15.n(21);8.a.2S=g.l(\'X\');8.a.2S.M=C+\'/t/S/2g.13\';21.n(8.a.2S);s 3P=g.l(\'2x\');1n.n(3P);8.a.1A=g.l(\'V\');8.a.1A.b.1L="1D("+C+"/t/S/f.13) 1X-x 1h 1M";8.a.1A.b.4R=\'2Y\';8.a.1A.b.12=\'60\';8.a.1A.b.3f=\'3O\';8.a.1A.55=4;3P.n(8.a.1A);8.a.2e=g.l(\'X\');8.a.2e.M=C+\'/t/S/4N.13\';8.a.2e.b.63=\'65\';8.a.1A.n(8.a.2e);T(8.a.1A,"1g",J(8,"2N"));s 3c=g.l(\'2x\');1n.n(3c);8.a.1w=g.l(\'V\');8.a.1w.b.12=\'54\';8.a.1w.55=4;3c.n(8.a.1w);8.D.n(1B);g.K.n(8.D)}c(8.9.F>0&&8.G[8.9.F].1J!=3Y)8.a.1w.1s=8.G[8.9.F].1J;m 8.a.1w.1s=\'\';8.D.b.P=\'59\';8.D.b.12=\'2p\';8.D.b.2O=\'3o\';c(3L==\'1l\'){8.D.16=\'5e\';8.D.b.1j="3i";8.D.b.1M=(1K[0]+(Z[2]-8.D.3m)/2)+\'1a\';8.D.b.2M="45"}m{8.D.b.1j="44";8.D.b.1h="0";8.D.b.1M=((Z[2]-8.D.3m)/2)+\'1a\';8.D.b.2M="45"}8.D.b.2O=\'3o\';T(8.a.2P,"1g",8.47);T(8.a.2R,"1g",8.2J);T(8.a.2S,"1g",8.2U);8.9.26=1d;T(8.a.2c,"1g",8.4a)};A.B.2l=v(){c(8.9.26){c(!8.9.1W)H(8.9.1u);8.a.2c.M=C+\'/t/S/26.13\';8.9.26=Y}m{H(8.9.1u);8.9.1u=11(8.2U,8.z["4b"]);8.a.2c.M=C+\'/t/S/2l.13\';8.9.26=1d}};A.B.4k=v(e){8.9.5E=1d;c(27==e.1H&&8.z[\'5F\'])8.3v();c(32==e.1H)8.2l();c(8.9.2v){c(38==e.1H){c(!8.9.2i)8.2N()}c(40==e.1H){c(8.9.2i)8.2N()}c(39==e.1H)8.2I();c(37==e.1H)8.2H();c(33==e.1H)8.2I();c(34==e.1H)8.2H()}};A.B.2N=v(){c(8.9.2i){c(3L!=\'1l\')8.D.b.1h="2Y";m 8.9.3Q=0;8.9.2i=Y;8.a.2e.M=C+\'/t/S/4N.13\'}m{c(3L!=\'1l\')8.D.b.1h="-62";m 8.9.3Q=28;8.9.2i=1d;8.a.2e.M=C+\'/t/S/57.13\'}};A.B.2H=v(){c(8.9.1W)R;8.9.1W=1d;8.9.2v=Y;c(8.9.F==0)8.9.j=1o(8.9.L)-1;m 8.9.j=1o(8.9.F)-1;c(8.z[\'1G\']){8.2m()}m{8.2T()}};A.B.2I=v(){c(8.9.1W)R;8.9.1W=1d;8.9.2v=Y;c(8.9.F==8.9.L-1)8.9.j=0;m 8.9.j=1o(8.9.F)+1;c(8.z[\'1G\']){8.2m()}m{8.2T()}};A.B.3v=v(){8.9.2v=Y;2V(g,"4x",8.3C);c(W.1R("2Z")!=-1){c(8.1p)2V(8.a.h[8.9.j],"2y",8.3a)}m{H(8.9.3d)}H(8.9.1u);H(8.9.3k);8.D.b.2O=\'5t\';1I(p 1N 8.G){c(8.a.h[p]&&8.a.h[p].4A!=1y){g.K.2s(8.a.h[p]);2V(8.a.h[p],"1g",8.2J)}}c(8.I!=1y){g.K.2s(8.I)}c(8.D!=1y){g.K.2s(8.D)}8.D=1y;8.I=1y;8.9.2Q=Y;8.3V()};',62,383,'||||||||this|work|lPhoto|style|if||||document|fscreenImg||next_photo||createElement|else|appendChild|||opacity|slides|var|img|100|function||||options|luckyPhoto|prototype|baseuri|lPhotoFNav|thumbs|now_photo|photos|clearTimeout|layer|luckyPhoto_createMethodReference|body|total_slides|src|next_slide|now_slide|width|id|return|lp|luckyPhoto_addEventListener|filter|TD||IMG|false|szArr||setTimeout|height|gif||tr1|className|MozOpacity|KhtmlOpacity|alpha|px|cell|luckyPhoto_ua|true|preload_slides|slideshow|click|top|preloadBig|position|yScroll|msie|now_photo_opasity|tb|parseInt|safariOnLoadStarted|next_photo_opasity|now_slide_opasity|innerHTML|complete|timeout_split_photos|td1|FCellDescr|next_slide_opasity|null|200|FCellHideUnhide|tbl|slide_timeout|url|buttonPrev|buttonNext|preload|keyCode|for|title|scrArr|background|left|in|offsetHeight|documentElement|windowHeight|indexOf|windowWidth|tr|preloadMedium|xScroll|changeFoto|repeat|fullscreenStartLink|jpg||td4|prev|arrow|listener||play|||event|preloadSmall|image_|FImgPlayPause|png|FImgArrow|obj|next|ThumbsTbl|navHided|lp_getPageSize|timeout_load_slides|pause|appendPhoto|slideNav|td2|50px|listenerStart|self|removeChild|DIV|td3|keysEnable|main|TR|load|window|splitSlide|slideDescr|listenerSplitSlide|opacitySpeed|resize|heightSz|widthSz|photoPrev|photoNext|stopListener|slides_height|gecko|right|navHideUnhide|visibility|FImgPrev|fullscreen|FImgClose|FImgNext|createPhoto|listenerNavNext|luckyPhoto_removeEventListener|innerHeight|lp_getPageScroll|0px|safari|opera|new||||Array|pageHeight||||listenerPreloadImage|pageWidth|tr3|timeout_preload_Photo|listenerSubinit|cursor|preloadImages|subinit|absolute|pix|timeout_change_opasity|no|offsetWidth|preloadImage|visible|padding|splitPhoto|display|listenerSplitPhoto|scrollTop|clientHeight|stop|TABLE|slideInit|TBODY|lPhotoFScreenImg|15px|zIndex|listenerKeyUp|object|background_opacity|loadFirstSlide|firstAppended|timeout_load_first_slide|preloadAllSlides|listenerPreloadAllSlides|td5|ua|listenerCachePhotoPreload|case|pointer|tr2|navUpHeight|loadThumbs|changeOpacity|break|td7|slideChange|listenerSlideChange|slideSpeed|undefined|yy||addStartToThumbs|start|popacity|fixed|auto||listenerNavPrev|widthFix|opacityFSpeed|listenerNavPlayPause|slideFSpeed|listenerChangeOpacity|speed|arrayPageScroll|cachePhoto|pageYOffset|scrollMaxY|scrollWidth|scrollHeight|keyListener|clientWidth|cachePhotoPreload|arguments|DXImageTransform|AlphaImageLoader|marginTop|cachePhotoStart|setNavigation|createSlideShowHTML|_el|lPhotoSlideTools|slides_width|keyup|progid|Microsoft|parentNode|sizingMethod|crop|backgroundImage|17px|center|on|listenerloadFirstSlide|appendOneSlide|_c_250|lPhotoSlideImg|listenerSlidePrev|listenerSlideNext|up|createThumbsHTML|timeout_load_preload_images|listenerSlideInit|border|marginLeft|1px|timeout_preload_cachePhoto|arrayPageSize|methodName|appended|timeout_load_thumbs|listenerLoadThumbs||slidePrev|slideNext|timeout_split_slides|20px|colSpan|_h_|down|_w_|300px|currentTarget|srcElement|split|_|lPhotoNavFixedIE|1001|1000|background_color|luckyPhotoLayer|backgroundAttachment|color|E5E5E5|font|weight|bold|Loading|lPhotoImgFixedIE|none|image_border|hidden|toLowerCase|mozilla|getElementById|attachEvent|99|removeEventListener|detachEvent|args|apply|innerWidth|stop_hide|stopESC|closeImg|tip|65px|init|lPhotoMain|lPhotoMainDiv|lPhotoSlideDiv|1005|lPhotoFScreenNavTable|textAlign|lPhotoSlideLinkStart|Watch|close|lPhotoThumbsTable|addEventListener|push|cloneNode|_c_80|switch|2px|8px|marginRight|28px|align|navigator|absmiddle|userAgent|getElementsByTagName|lPhotoThumbImg|thumbs_|70'.split('|'),0,{}))

